身邊有幾個做PHP開發的朋友,也接觸到不少的PHP工程師,他們常疑慮自己將來在技術上的成長與發展,我常給他們一些建議,希望他們能破突自己,有更好的發展。
先明確我所指的PHP工程題,是指畢業工作後,主要以PHP進行WEB系統的開發,沒有使用其的語言工作過。工作經驗大概在3~4年,普通的WEB系統(百萬級訪問,千成級數據以內或業務邏輯不是特別復雜)開發起基本得心應手,沒有什麼問題。但他們會這樣的特點:
這些PHPer 在遇到需要高性能,處理高並發,大量數據的項目或業務邏輯比較復雜(系統需要解決多領域業務的問題)時,缺少思路。不能分析問題的本質,技術判斷力比較差,對於問題較快能找出臨時的解決辦法,但常常在不斷臨時性的解決辦法中,系統和自己一步步走向崩潰。那怎麼提高自己呢?怎麼可以挑戰難度更高的系統?
更高的挑戰在那裡?結合我自己的經驗,我列出一些具體挑戰,讓大家先有個感性的認識。
高性能系統的挑戰在那裡?
高復雜性系統的挑戰在那裡?
當我所列出的問題,你都能肯定的回答,我想在技術上你基本已經可能成為架構師了。如何你還不能回答,你需要在以下幾個方向加強。
如何你還不能回答,你需要在以下幾個方向加強:
"這麼多的東西怎麼學,這得學多久呀" ?如果你努力的話,有較好的規劃,估計需要1~2年的時間。
如何有效的學習是一個大問題。 自己有些實踐但很零散,不好總結。昨天晚上睡覺前,突然想到了RUP的核心,"以架構為中心,用例驅動,迭代開發",借用這個思想,關於有效的學習的方法,可以這樣來表述:以原理、模型或機制為中心,任務驅動,迭代學習。
有點抽象, 舉個例子來說明如何學習。目的: 學習如何提高處理性能。
可迭代驅動的任務: 通過IP找到所在地域。
這是WEB應用常見的任務,IP數據庫是10左右萬行的記錄。
第一次迭代: 不考慮性能的情況下實現功能(通過PHP來實現)。因為無法直接通過KEY(IP)進行查找地域,所以直接放到數據或通過關聯數組這種簡單的方法都是不行的。思路還是先把數據進行排序,然後再進行查找。
學習目標: 排序算法,查找算法。
PHPer 一般數據結構和算法基礎比較差,平時也沒有這方面的任務,自己也不學習,因此這方面的知識很缺乏。但是,編程解決的問題,最終都會歸結到數據結構和對這種數據結構操作的算法。如果數據結構算法常在心中,那遇到問題就能清晰認識到它內在的結構,解決方法就會自然產生。
第二次迭代:優化數據的加載與排序。如果做到第一步,那基本上還是不可用,因為數據每次都需要的加載和排序,這樣太耗時間。 解決的思路是,數據一次加載排序後,放到每個PHP進程能訪問到的地方。
放到memcache 這是大家容易想到問題。其實放到共享內存(EA等加速器都支持)中是更快的方式,因為memcache還多了網絡操作。 數據是整體放入到共享內存,還是分塊放入,如何測試性能? 如何分析瓶頸所在(xdebug)? 在這些問題的驅動下你會學習到。
學習目標: 檢測、定位、優化PHP性能的方法; PHP實現結構對性能的影響。
第三次迭代: 編寫PHP的擴展。性能還是上不去,不得不進入C/C++的世界了,不過從此你將不只是PHPer 而服務端的全能型工程師,當然這對沒有做過C/C++的同學挑戰是巨大的。 我這裡無法再簡單來說如何學習C/C++ ,可以參看 《PHP程序員學習C++》
學習目標:C/C++的學習,PHP擴展的編寫
怎麼確定需要學習的機制和原理呢? 怎麼找到驅動學習任務呢?我對需要學習的東西,都沒有什麼概念,怎麼回答以上的兩個問題?
假如我需要學習Javascript ,我對於HTML,CSS有點感性認識。首要我了解到,JS 是WEB領域的動態語言,主要解決網頁的動態交互的。那我要學習的要點如下:
如果完全自學,找到需要學習的要點(機制、模型、原理) 設定學習任務的確不是那麼容易把握。如果找到一個有經驗的人來指導你或加一個學習型的團隊,那學習的速度的確會大大提高。