1. 程式人生 > >php程式設計師要努力突破的瓶頸-----php要提升的

php程式設計師要努力突破的瓶頸-----php要提升的

作為Web開發中應用最廣泛的語言之一,PHP有著大量的粉絲,那麼你是一名優秀的程式設計師嗎?在進行自我修煉的同時,你是否想過面對各種各樣的問題,我該如何突破自身的瓶頸,以便更好的發展呢?

PHP工程師面臨成長瓶頸

先明確這裡所指的PHP工程師,是指主要以PHP進行Web系統的開發,沒有使用其的語言工作過。工作經驗大概在3~4年,普通的Web系統(百萬級訪問,千成級資料以內或業務邏輯不是特別複雜)開發起基本得心應手,沒有什麼問題。但他們會這樣的物點:

◆除了PHP不使用其它的語言,可能會點shell 指令碼。

◆對PHP的掌握不精(很多PHP手冊都沒有看完,庫除外)。

◆知識面比較窄(面對需求,除開使用PHP和mysql ,不知道其它的解決辦法)。

◆PHP程式碼以過程為主,認為面向物件的實現太繞,看不懂。

這些PHPer在遇到需要高效能,處理高併發,大量資料的專案或業務邏輯比較複雜(系統需要解決多領域業務的問題)時,缺少思路。不能分析問題的本質,技術判斷力比較差,對於問題較快能找出臨時的解決辦法,但常常在不斷臨時性的解決辦法中,系統和自己一步步走向崩潰。那怎麼提高自己呢?怎麼可以挑戰難度更高的系統?

更高的挑戰在那裡?

結合我自己的經驗,我列出一些具體挑戰,讓大家先有個感性的認識。

高效能系統的挑戰在那裡?

◆如何選擇Web伺服器?要不要使用fast-cgi 模式;

◆要不要使用反向代理服務?選擇全記憶體快取還是硬碟快取?

◆是否需要負載均衡?是基於應用層,還是網路層? 如何保證高可靠性?

◆你的PHP程式碼效能如何,使用優化工具後怎麼樣? 效能瓶頸在那裡? 是否需要寫成C的擴充套件?

◆使用者訪問有什麼特點,是讀多還是寫多?是否需要讀寫分離?

◆資料如何儲存?寫入速度和讀出速度如何? 資料增漲訪問速讀如何變化?

◆如何使用快取? 怎麼樣考慮失效?資料的一致性怎麼保證?

高複雜性系統的挑戰在那裡?

◆能否識別業務所對應的領域?是一個還是多個?

◆能否合理對業務進行抽象,在業務規則變化能以很小的代價實現?

◆資料的一致性、安全性可否保證?

◆是否撐握了面向物件的分析和設計的方法

這裡所列出的問題,你都能肯定的回答,說明在技術上你基本已經可能成為架構師了。如何你還不能回答,你需要在以下幾個方向加強。

怎麼樣提高,突破瓶頸

如何你還不能回答,你需要在以下幾個方向加強:

◆分析你所使用的技術其原理和背後執行的機制,這樣可以提高你的技術判斷力,提高你技術方案選擇的正確性;

◆學習大學期間重要的知識, 作業系統原理,資料結構和演算法。知道你以前學習都是為了考試,但現在你需要為自己學習,讓自己知其所以然;

◆重新開始學習C語言,雖然你在大學已經學過。這不僅是因為你可能需要寫PHP擴充套件,而且還因為,在做C的應用中,有一個時刻關心效能、記憶體控制、變數生命週期、資料結構和演算法的環境;

◆學習面向物件的分析與設計,它是解決複雜問題的有效的方法。學習抽象,它是解決複雜問題的唯一之道。

如何有效的學習是一個大問題。“以架構為中心,用例驅動,迭代開發”,借用這個思想,關於有效的學習的方法,可以這樣來表述:以原理、模型或機制為中心,任務驅動,迭代學習。有點抽象, 舉個例子來說明如何學習。

目的: 學習如何提高處理效能。

可迭代驅動的任務: 通過IP找到所在地域。這是Web應用常見的任務,IP資料庫是10左右萬行的記錄。

第一次迭代: 不考慮效能的情況下實現功能(通過PHP來實現)

因為無法直接通過KEY(IP)進行查詢地域,所以直接放到資料或通過關聯陣列這種簡單的方法都是不行的。思路還是先把資料進行排序,然後再進行查詢:

◆如何通過IP查詢?已序的資料,二分查詢是最快的。

◆如何排序?用庫函式sort當然是可以,但是即然是學習,那還是自己實現快速排序吧。

學習目標: 排序演算法,查詢演算法

PHPer資料結構和演算法基礎比較差,平時也沒有這方面的任務,自己也不學習,因此這方面的知識很缺乏。但是,程式設計解決的問題,最終都會歸結到資料結構和對這種資料結構操作的演算法。如果資料結構演算法常在心中,那遇到問題就能清晰認識到它內在的結構,解決方法就會自然產生。

第二次迭代:優化資料的載入與排序

如果做到第一步,那基本上還是不可用,因為資料每次都需要的載入和排序,這樣太耗時間。 解決的思路是,資料一次載入排序後,放到每個PHP程序能訪問到的地方。放到Memcache這是大家容易想到問題。其實放到共享記憶體(EA等加速器都支援)中是更快的方式,因為memcache還多了網路操作。 資料是整體放入到共享記憶體,還是分塊放入,如何測試效能? 如何分析瓶頸所在(xdebug)? 在這些問題的驅動下你會學習到。

學習目標: 檢測、定位、優化PHP效能的方法; PHP實現結構對效能的影響。

第三次迭代: 編寫PHP的擴充套件

效能還是上不去,不得不進入C/C++的世界了,不過從此你將不只是PHPer 而服務端的全能型工程師,當然這對沒有做過C/C++的同學挑戰是巨大的。

學習目標:C/C++的學習,PHP擴充套件的編寫

怎麼確定需要學習的機制和原理呢? 怎麼找到驅動學習任務呢?我對需要學習的東西,都沒有什麼概念,怎麼回答以上的兩個問題? 從這個技術的定位來找出需要學習的重點,即它怎麼做到(機制)的和它為什麼能這樣做到。列出這個技術最常見的應用,做為學習的任務,從簡到難進行實踐。

假如我需要學習JavaScript,我對於HTML,CSS有點感性認識。首要要了解的是,JavaScript是Web領域的動態語言,主要解決網頁的動態互動的。那要學習的要點如下:

◆JavaScript如何與HTML進行互動 (機制)

◆JavaScript的動態特性在那裡,與其它動態語言有何區別?(語言模型)

如果完全自學,找到需要學習的要點(機制、模型、原理) 設定學習任務的確不是那麼容易把握。如果找到一個有經驗的人來指導你或加一個學習型的團隊,那學習的速度的確會大大提高。

技術的快速進步,最好的途徑就是閱讀原始碼了。自己也閱讀了很多開源的程式,感覺方法很重要,好的方法可以達到事半功倍的效果。一下就是我自己的一些新的,希望對大家都有用。
    一份好的原始碼例如 dz的論壇,wind論壇,帝國cms,dedecms等,都具有自己的一套設計思路和設計模式,所以在看某個產品之前就要做好心理準備,可以把自己的經驗和這些產品做對比,但千萬別一直用自己的思維去評判。一句話就是“以學習和批評的辯證思想去看待”。
     好吧!我們就開始吧!
     那具體的我們怎樣去閱讀一份php的原始碼呢?
    一。先把原始碼安裝起來,結合它的文件和手冊,熟悉其功能和它的應用方式。
    二。瀏覽原始碼的目錄結構,瞭解各個目錄的功能。
    三。經過以上兩步後相信你對這個開源的產品有了一個初步的瞭解了,那現在就開始分析它的原始碼吧。這一步我們開始分析原始碼框架。例如入口方式是單入口還是多入口,頁面之間的呼叫規則,能根據規則找出某個功能用到的頁面。
    四。熟悉原始碼的程式碼寫作風格,例如縮排方式,排版格式等。
    五。熟悉一下原始碼用到的資料庫和表,可以參考它的技術支援文件。
    六。經過以上幾步相信大家已經對這份原始碼有了更深刻的瞭解,不過這種瞭解還只是表面的,下來我們從6個方面具體的去分析它吧:
           1.入口構造以及頁面呼叫方式的具體實現,如果閱讀時看到工具類和工具函式,儘量去熟悉一下。這一步的分析可以學習到原始碼的系統架構方式。
           2.分析原始碼用到的工具類和工具函式,這樣可以學到很多程式編寫技巧。可以提升自己程式設計功力。
           3.結合一些安全規則,研究這個原始碼是怎樣實現安全方面的設計的。這樣可以提高自己在安全方面的意識和功力。
           4.如果有模板引擎的話,研究一下原始碼的模板引擎。大致從實現方式,效率,易用性等幾個方面去考慮。
           5.研究系統的各個功能模組,這樣既能學習程式設計技巧還能開啟自己的程式設計思路,下次遇到類似的東東就心裡有譜了。
           6.研究系統所用到設計模式,一樣的功能實現,用到的設計模式可能相差很多,對比我們之前所作的東東分析設計模式,是提升我們駕馭程式碼的不二法門。
           7.研究原始碼對訪問壓力,執行效率,系統效率,資料庫查詢的優化。    
       方法只是途徑和工具,具體實踐還需要大家的努力。自己的感想是不要著急,認真分析,把分析心得用到自己的具體專案上,呵呵!

最後,想對大家說:PHP因為簡單而使用,但不能因為它的簡單而限制我們成長!