忽然看到這篇文章, 值得檢討, 樂在其中, 在接下來的發展中不被淘汰的都來看看,shell
如何成爲一個架構師
先明確這裏所指的PHP工程師,是指主要以PHP進行Web系統的開發,沒有使用其的語言工做過。工做經驗大概在3~4年,普通的Web系統(百萬級訪問,千成級數據之內或業務邏輯不是特別複雜)開發起基本駕輕就熟,沒有什麼問題。但他們會有這樣的誤點:緩存
◆ 除了PHP不使用其它的語言,可能會點shell 腳本。安全
◆ 對PHP的掌握不精(不少PHP手冊都沒有看完,庫除外)。服務器
◆ 知識面比較窄(面對需求,除開使用PHP和MYSQL,不知道其它的解決辦法)。網絡
◆ PHP代碼以過程爲主,認爲面向對象的實現太繞,看不懂。數據結構
這些PHPer在遇到須要高性能,處理高併發,大量數據的項目或業務邏輯比較複雜(系統須要解決多領域業務的問題)時,缺乏思路。不能分析問題的本質,技術判斷力比較差,對於問題較快能找出臨時的解決辦法,但經常在不斷臨時性的解決辦法中,系統和本身一步步走向崩潰。那怎麼提升本身呢?怎麼能夠挑戰難度更高的系統?架構
更高的挑戰在那裏?併發
結合我本身的經驗,我列出一些具體挑戰,讓你們先有個感性的認識。負載均衡
高性能系統的挑戰在那裏?
◆ 如何選擇Web服務器?要不要使用fast-cgi 模式;
◆ 要不要使用反向代理服務?選擇全內存緩存仍是硬盤緩存?
◆ 是否須要負載均衡?是基於應用層,仍是網絡層? 如何保證高可靠性?
◆ 你的PHP代碼性能如何,使用優化工具後怎麼樣? 性能瓶頸在那裏? 是否須要寫成C的擴展?
◆ 用戶訪問有什麼特色,是讀多仍是寫多?是否須要讀寫分離?
◆ 數據如何存儲?寫入速度和讀出速度如何? 數據增漲訪問速讀如何變化?
◆ 如何使用緩存? 怎麼樣考慮失效?數據的一致性怎麼保證?
高複雜性系統的挑戰在那裏?
◆ 可否識別業務所對應的領域?是一個仍是多個?
◆ 可否合理對業務進行抽象,在業務規則變化能以很小的代價實現?
◆ 數據的一致性、安全性能否保證?
◆ 是否撐握了面向對象的分析和設計的方法?
這裏所列出的問題,你都能確定的回答,說明在技術上你基本已經可能成爲架構師了。如何你還不能回答,你須要在如下幾個方向增強。
怎麼樣提升,突破瓶頸
如何你還不能回答,你須要在如下幾個方向增強:
◆ 分析你所使用的技術其原理和背後運行的機制,這樣能夠提升你的技術判斷力,提升你技術方案選擇的正確性;
◆ 學習大學期間重要的知識,操做系統原理,數據結構和算法。知道你之前學習都是爲了考試,但如今你須要爲本身學習,讓本身知其因此然;
◆ 從新開始學習C語言,雖然你在大學已經學過。這不只是由於你可能須要寫PHP擴展,並且還由於,在作C的應用中,有一個時刻關心性能、內存控制、變量生命週期、數據結構和算法的環境;
◆ 學習面向對象的分析與設計,它是解決複雜問題的有效的方法。學習抽象,它是解決複雜問題的惟一之道。