天天看點

PHP程式員的技術成長規劃

按照了解的很多php/lnmp程式員的發展軌迹,結合個人經驗體會,抽象出很多程式員對未來的迷漫,特别對技術學習的盲目和慌亂,簡單梳理了這個每個階段php程式員的技術要求,來幫助很多php程式做對照設定學習成長目标。

PHP程式員的技術成長規劃

   本文按照目前主流技術做了一個基本的梳理,整個是假設php程式員不是基礎非常紮實的情況進行的設定,并且所有設定都非常具體明确清晰,可能會讓人覺得不适,請了解僅代表一家之言。(未來技術變化不在讨論範圍)

<a></a>

重點:把lnmp搞熟練(核心是安裝配置基本操作)

目标:能夠完成基本的lnmp系統安裝,簡單配置維護;能夠做基本的簡單系統的php開發;能夠在php中型系統中支援某個php功能子產品的開發。

時間:完成本階段的時間因人而異,有的成長快半年一年就過了,成長慢的兩三年也有。

1.linux:

基本指令、操作、啟動、基本服務配置(包括rpm安裝檔案,各種服務配置等);會寫簡單的shell腳本和awk/sed 腳本指令等。

2.nginx:

做到能夠安裝配置nginx+php,知道基本的nginx核心配置選項,知道 server/fastcgi_pass/access_log 等基礎配置,目标是能夠讓nginx+php_fpm順利工作。

3.mysql:

會自己搭建mysql,知道基本的mysql配置選項;知道innodb和myisam的差別,知道針對innodb和myisam兩個引擎的不同配置選項;知道基本的兩個引擎的差異和選擇上面的差別;能夠純手工編譯搭建一個mysql資料庫并且配置好編碼等正常穩定運作;核心主旨是能夠搭建一個可運作的mysql資料庫。

4.php:

基本文法數組、字元串、資料庫、xml、socket、gd/imagemgk圖檔處理等等;熟悉各種跟mysql操作連結的api(mysql/mysqli/pdo),知道各種編碼問題的解決;知道正常熟練使用的php架構(thinkphp、zendframework、yii、yaf等);了解基本mvc的運作機制和為什麼這麼做,稍微知道不同的php架構之間的差別;能夠快速學習一個mvc架構。能夠知道開發工程中的檔案目錄組織,有基本的良好的代碼結構和風格,能夠完成小系統的開發和中型系統中某個子產品的開發工作。

5.前端:

如果條件時間允許,可以适當學習下 html/css/js 等相關知識,知道什麼web标準,div+css的web/wap頁面模式,知道html5和html4的差別;了解一些基本的前端隻是和js架構(jquery之類的);了解一些基本的javascript程式設計知識;(本項不是必須項,如果有時間,稍微了解一下是可以的,不過不建議作為重點,除非個人有強烈興趣)

6.系統設計:

能夠完成小型系統的基本設計,包括簡單的資料庫設計,能夠完成基本的:浏覽器 -&lt; nginx+php -&lt; 資料庫 架構的設計開發工作;能夠支撐每天幾十萬到數百萬流量網站的開發維護工作;

重點:提高針對lnmp的技能,能夠更全面的對lnmp有熟練的應用。

目标:能夠随時随地搭建好lnmp環境,快速完成正常配置;能夠追查解決大部分遇到的開發和線上環境的問題;能夠獨立承擔中型系統的構架和開發工作;能夠在大型系統中承擔某個中型子產品的開發工作;

1. linux:

在第一階段的基礎上面,能夠流暢的使用shell腳本來完成很多自動化的工作;awk/sed/perl 也操作的不錯,能夠完成很多文本處理和資料統計等工作;基本能夠安裝大部分非特殊的linux程式(包括各種庫、包、第三方依賴等等,比如mongodb/redis/sphinx/luncene/svn之類的);了解基本的linux服務,知道如何檢視linux的性能名額資料,知道基本的linux下面的問題跟蹤等。

2. nginx:

在第一階段的基礎上面,了解複雜一些的nginx配置;包括 多核配置、events、proxy_pass,sendfile/tcp_*配置,知道逾時等相關配置和性能影響;知道nginx除了web server,還能夠承擔代理伺服器、反向靜态伺服器等配置;知道基本的nginx配置調優;知道如何配置權限、編譯一個nginx擴充到nginx;知道基本的nginx運作原理(master/worker機制,epoll),知道為什麼nginx性能比apache性能好等知識;

3. mysql/mongodb:

在第一階段的基礎上面,在mysql開發方面,掌握很多小技巧,包括正常sql優化(group by/order by/rand優化等);除了能夠搭建mysql,還能夠冷熱備份mysql資料,還知道影響innodb/myisam性能的配置選項(比如key_buffer/query_cache/sort_buffer/innodb_buffer_pool_size/innodb_flush_log_at_trx_commit等),也知道這些選項配置成為多少值合适;另外也了解一些特殊的配置選項,比如  知道如何搭建mysql主從同步的環境,知道各個binlog_format的差別;知道mysql的性能追查,包括slow_log/explain等,還能夠知道基本的索引建立處理等知識;原理方面了解基本的mysql的架構(server+存儲引擎),知道基本的innodb/myisam索引存儲結構和不同(聚簇索引,b樹);知道基本的innodb事務處理機制;了解大部分mysql異常情況的處理方案(或者知道哪兒找到處理方案)。條件允許的情況,建議了解一下nosql的代表mongodb資料庫,順便對比跟mysql的差别,同僚能夠在合适的應用場景安全謹慎的使用mongodb,知道基本的php與mongodb的結合開發。

4. redis/memcached:

在大部分中型系統裡面一定會涉及到緩存處理,是以一定要了解基本的緩存;知道memcached和redis的異同和應用場景,能夠獨立安裝 redis/memcached,了解memcahed的一些基本特性和限制,比如最大的value值,知道php跟他們的使用結合;redis了解基本工作原理和使用,了解正常的資料類型,知道什麼場景應用什麼類型,了解redis的事務等等。原理部分,能夠大概了解memcached的記憶體結構(slab機制),redis就了解常用資料類型底層實作存儲結構(sds/連結清單/skiplist/hashtable)等等,順便了解一下redis的事務、rdb、aof等機制更好

5. php:

除了第一階段的能力,安裝配置方面能夠随意安裝php和各種第三方擴充的編譯安裝配置;了解php-fpm的大部配置設定置選項和含義(如max_requests/max_children/request_terminate_timeout之類的影響性能的配置),知道mod_php/fastcgi的差別;在php方面已經能夠熟練各種基礎技術,還包括各種深入些的php,包括對php面向對象的深入了解/spl/文法層面的特殊特性比如反射之類的;在架構方面已經閱讀過最少一個以上正常php mvc架構的代碼了,知道基本php架構内部實作機制和設計思想;在php開發中已經能夠熟練使用正常的設計模式來應用開發(抽象工廠/單例/觀察者/指令鍊/政策/擴充卡 等模式);建議開發自己的php mvc架構來充分讓開發自由化,讓自己深入了解mvc模式,也讓自己能夠在業務項目開發裡快速更新;熟悉php的各種代碼優化方法,熟悉大部分php安全方面問題的解決處理;熟悉基本的php執行的機制原理(zend引擎/擴充基本工作機制);

6. c/c++:

開始涉獵一定的c/c++語言,能夠寫基本的c/c++代碼,對基本的c/c++文法熟悉(指針、數組操作、字元串、正常标準api)和資料結構(連結清單、樹、哈希、隊列)有一定的熟悉下;對linux下面的c語言開發有基本的了解概念,會簡單的makefile檔案編寫,能夠使用簡單的gcc/gdb的程式編譯簡單調試工作;對基本的網絡程式設計有大概了解。(本項是為了向更高層次打下基礎)

7. 前端:

在第一階段的基礎上面,熟悉基本的http協定(協定代碼200/300/400/500,基本的http互動頭);條件允許,可以在深入寫出稍微優雅的html+css+javascript,或者能夠大緻簡單使用某些前端架構(jquery/yui/extjs/requirejs/bootstrap之類);如果條件允許,可以深入學習javascript程式設計,比如閉包機制、dom處理;再深入些可以讀讀jquery源碼做深入學習。(本項不做重點學習,除非對前端有興趣)

8. 系統設計:

能夠設計大部分中型系統的網站架構、資料庫、基本php架構選型;性能測試排查處理等;能夠完成類似:浏覽器 -&lt; cdn(squid) -&lt; nginx+php -&lt; 緩存 -&lt; 資料庫 結構網站的基本設計開發維護;能夠支撐每天數百萬到千萬流量基本網站的開發維護工作;

重點:除了基本的lnmp程式,還能夠在某個方向或領域有深入學習。(縱深次元發展)

目标:除了能夠完成基本的php業務開發,還能夠解決大部分深入複雜的技術問題,并且可以獨立設計完成中大型的系統設計和開發工作;自己能夠獨立hold深入某個技術方向,在這塊比較專業。(比如在mysql、nginx、php、redis等等任一方向深入研究)

1. linux:

除了第二階段的能力,在linux下面除了正常的操作和性能監控跟蹤,還能夠使用很多進階複雜的指令完成工作(watch/tcpdump/starce/ldd/ar等);在shell腳本方面,已經能夠編寫比較複雜的shell腳本(超過500行)來協助完成很多包括備份、自動化處理、監控等工作的shell;對awk/sed/perl 等應用已經如火純青,能夠随意操作控制處理文本統計分析各種複雜格式的資料;對linux内部機制有一些了解,對核心子產品加載,啟動錯誤處理等等有個基本的處理;同時對一些其他相關的東西也了解,比如nfs、磁盤管理等等;

在第二階段的基礎上面,已經能夠把nginx操作的很熟練,能夠對nginx進行更深入的運維工作,比如監控、性能優化,複雜問題處理等等;看個人興趣,更多方面可以考慮側重在關于nginx工作原理部分的深入學習,主要表現在閱讀源碼開始,比如具體的master/worker工作機制,nginx内部的事件處理,記憶體管理等等;同時可以學習nginx擴充的開發,可以定制一些自己私有的擴充;同時可以對nginx+lua有一定程度的了解,看看是否可以結合應用出更好模式;這個階段的要求是對nginx原理的深入了解,可以考慮成為nginx方向的深入專業者。

在第二階段的基礎上面,在mysql應用方面,除了之前的基本sql優化,還能夠在完成一些複雜操作,比如大批量資料的導入導出,線上大批量資料的更改表結構或者增删索引字段等等高危操作;除了安裝配置,已經能夠處理更多複雜的mysql的問題,比如各種問題的追查,主從同步延遲問題的解決、跨機房同步資料方案、mysql高可用架構等都有涉及了解;對mysql應用層面,對mysql的核心關鍵技術比較熟悉,比如事務機制(隔離級别、鎖等)、對觸發器、分區等技術有一定了解和應用;對mysql性能方面,有包括磁盤優化(sas遷移到ssd)、伺服器優化(記憶體、伺服器本身配置)、除了二階段的其他核心性能優化選項(innodb_log_buffer_size/back_log/table_open_cache/thread_cache_size/innodb_lock_wait_timeout等)、連接配接池軟體選擇應用,對show *(show status/show profile)類的操作語句有深入了解,能夠完成大部分的性能問題追查;mysql備份技術的深入熟悉,包括災備還原、對binlog的深入了解,冷熱備份,多idc備份等;在mysql原理方面,有更多了解,比如對mysql的工作機制開始閱讀部分源碼,比如對主從同步(複制)技術的源碼學習,或者對某個存儲引擎(myisam/innodb/tokudb)等等的源碼學習了解,如果條件允許,可以參考csv引擎開發自己簡單的存儲引擎來儲存一些資料,增強對mysql的了解;在這個過程,如果自己有興趣,也可以考慮往dba方向發展。mongodb層面,可以考慮比如說在寫少讀多的情況開始線上上應用mongodb,或者是做一些線上的資料分析處理的操作,具體場景可以按照工作來,不過核心是要更好的深入了解rmdbs和nosql的不同場景下面的應用,如果條件或者興趣允許,可以開始深入學習一下mongodb的工作機制。

在第二階段的基礎上面,能夠更深入的應用和學習。因為memcached不是特别複雜,建議可以把源碼進行閱讀,特别是記憶體管理部分,友善深入了解;redis部分,可以多做一些複雜的資料結構的應用(zset來做排行榜排序操作/事務處理用來保證原子性在秒殺類場景應用之類的使用操作);多涉及aof等同步機制的學習應用,設計一個高可用的redis應用架構和叢集;建議可以深入的學習一下redis的源碼,把在第二階段積累的知識都可以應用上,特别可以閱讀一下包括核心事件管理、記憶體管理、内部核心資料結構等充分學習了解一下。如果興趣允許,可以成為一個redis方面非常專業的使用者。

作為基礎核心技能,我們在第二階段的基礎上面,需要有更深入的學習和應用。從基本代碼應用上面來說,能夠解決在php開發中遇到95%的問題,了解大部分php的技巧;對大部分的php架構能夠迅速在一天内上手使用,并且了解各個主流php架構的優缺點,能夠迅速友善項目開發中做技術選型;在配置方面,除了正常第二階段會的知識,會了解一些比較偏門的配置選項(php auto_prepend_file/auto_append_file),包括擴充中的一些複雜進階配置和原理(比如memcached擴充配置中的memcache.hash_strategy、apc擴充配置中的apc.mmap_file_mask/apc.slam_defense/apc.file_update_protection之類的);對php的工作機制比較了解,包括php-fpm工作機制(比如php-fpm在不同配置機器下面開啟程序數量計算以及原理),對zend引擎有基本熟悉(vm/gc/stream處理),閱讀過基本的php核心源碼(或者閱讀過相關文章),對php内部機制的大部分核心資料結構(基礎類型/array/object)實作有了解,對于核心基礎結構(zval/hashtable/gc)有深入學習了解;能夠進行基本的php擴充開發,了解一些擴充開發的中進階知識(minit/rinit等),熟悉php跟apache/nginx不同的通信互動方式細節(mod_php/fastcgi);除了開發php擴充,可以考慮學習開發zend擴充,從更底層去了解php。

在第二階段基礎上面,能夠在c/c++語言方面有更深入的學習了解,能夠完成中小型c/c++系統的開發工作;除了基本第二階段的基礎c/c++文法和資料結構,也能夠學習一些特殊資料結構(b-tree/rb-tree/skiplist/lsm-tree/trie-tree等)友善在特殊工作中需求;在系統程式設計方面,熟悉多程序、多線程程式設計;多程序情況下面了解大部分多程序之間的通信方式,能夠靈活選擇通信方式(共享記憶體/信号量/管道等);多線程程式設計能夠良好的解決鎖沖突問題,并且能夠進行多線程程式的開發調試工作;同時對網絡程式設計比較熟悉,了解多程序模型/多線程模型/異步網絡io模型的差别和選型,熟悉不同異步網絡io模型的原理和差異(select/poll/epoll/iocp等),并且熟悉常見的異步架構(ace/ice/libev/libevent/libuv/boost.asio等)和使用,如果閑暇也可以看看一些國産自己開發的庫(比如muduo);同時能夠設計好的高并發程式架構(leader-follow/master-worker等);了解大部分c/c++後端server開發中的問題(記憶體管理、日志列印、高并發、前後端通信協定、服務監控),知道各個後端服務rpc通信問題(struct/http/thirft/protobuf等);能夠更熟絡的使用gcc和gdb來開發編譯調試程式,線上上程式core掉後能夠迅速追查跟蹤解決問題;通用子產品開發方面,可以積累或者開發一些通用的工具或庫(比如異步網絡架構、日志庫、記憶體池、線程池等),不過開發後是否應用要謹慎,省的埋坑去追bug;

深入了解http協定(包括各個細緻協定特殊協定代碼和背後原因,比如302靜态檔案緩存了,502是nginx後面php挂了之類的);除了之前的前端方面的各種架構應用整合能力,前端方面的學習如果有興趣可以更深入,表現形式是,可以自己開發一些類似jquery的前端架構,或者開發一個富文本編輯器之類的比較瑣碎考驗javascript功力;

8. 其他領域語言學習:

在基礎的php/c/c++語言方面有基本積累,建議在目前階段可以嘗試學習不同的程式設計語言,看個人興趣愛好,腳本類語言可以學學 python/ruby 之類的,函數式程式設計語言可以試試 lisp/haskell/scala/erlang 之類的,靜态語言可以試試 java/golang,資料統計分析可以了解了解r語言,如果想換個視角做後端業務,可以試試 node.js還有前面提到的跟nginx結合的nginx_lua等。學習不同的語言主要是提升自己的視野和解決問題手段的差異,比如會了解除了程序/線程,還有輕量級協程;比如在跨機器通信場景下面,erlang的解決方案簡單的驚人;比如在不想選擇c/c++的情況下,還有類似高效的erlang/golang可用等等;主要是提升視野。

9. 其他專業方向學習:

在本階段裡面,會除了基本的lnmp技能之外,會考慮一些其他領域知識的學習,這些都是可以的,看個人興趣和長期的目标方向。目前情況能夠選擇的領域比較多,比如、雲計算(分布式存儲、分布式計算、虛拟機等),機器學習(資料挖掘、模式識别等,應用到統計、個性化推薦),自然語言處理(中文分詞等),搜尋引擎技術、圖形圖像、語音識别等等。除了這些高大上的,也有很多偏工程方面可以學習的地方,比如高性能系統、移動開發(android/ios)、計算機安全、嵌入式系統、硬體等方向。

10. 系統設計:

系統設計在第二階段的基礎之上,能夠應用掌握的經驗技能,設計出比較複雜的中大型系統,能夠解決大部分線上的各種複雜系統的問題,完成類似 浏覽器 -&lt; cdn -&lt; 負載均衡 -&lt;接入層 -&lt; nginx+php -&lt; 業務緩存 -&lt; 資料庫 -&lt; 各路複雜後端rpc互動(存儲後端、邏輯後端、反作弊後端、外部服務) -&lt; 更多後端 醬紫的複雜業務;能夠支撐每天數千萬到數億流量網站的正常開發維護工作。

ps: 暫時不展開讨論,等下次專門撰文來描述補充本部分内容

ps:高大上,這塊不展開讨論 ^_^

作者:wozhuzaisi

來源:51cto