第三階段:高級(jí)階段 (高級(jí)PHP程序員) 重點(diǎn):除了基本的LNMP程序,還能夠在某個(gè)方向或領(lǐng)域有深入學(xué)習(xí)。(縱深維度發(fā)展) 目標(biāo):除了能夠完成基本的PHP業(yè)務(wù)開(kāi)發(fā),還能夠解決大部分深入復(fù)雜的技術(shù)問(wèn)題,并且可以獨(dú)立設(shè)計(jì)完成中大型的系統(tǒng)設(shè)計(jì)和開(kāi)發(fā)工作;自己能夠獨(dú)立hold深入某個(gè)技術(shù)方向,在這塊比較專(zhuān)業(yè)。(比如在MySQL、Nginx、PHP、Redis等等任一方向深入研究)
1. Linux: 除了第二階段的能力,在Linux下面除了常規(guī)的操作和性能監(jiān)控跟蹤,還能夠使用很多高級(jí)復(fù)雜的命令完成工作(watch/tcpdump/starce/ldd/ar等);在shell腳本方面,已經(jīng)能夠編寫(xiě)比較復(fù)雜的shell腳本(超過(guò)500行)來(lái)協(xié)助完成很多包括備份、自動(dòng)化處理、監(jiān)控等工作的shell;對(duì)awk/sed/perl 等應(yīng)用已經(jīng)如火純青,能夠隨意操作控制處理文本統(tǒng)計(jì)分析各種復(fù)雜格式的數(shù)據(jù);對(duì)Linux內(nèi)部機(jī)制有一些了解,對(duì)內(nèi)核模塊加載,啟動(dòng)錯(cuò)誤處理等等有個(gè)基本的處理;同時(shí)對(duì)一些其他相關(guān)的東西也了解,比如NFS、磁盤(pán)管理等等;
2. Nginx: 在第二階段的基礎(chǔ)上面,已經(jīng)能夠把Nginx操作的很熟練,能夠?qū)ginx進(jìn)行更深入的運(yùn)維工作,比如監(jiān)控、性能優(yōu)化,復(fù)雜問(wèn)題處理等等;看個(gè)人興趣,更多方面可以考慮側(cè)重在關(guān)于Nginx工作原理部分的深入學(xué)習(xí),主要表現(xiàn)在閱讀源碼開(kāi)始,比如具體的master/worker工作機(jī)制,Nginx內(nèi)部的事件處理,內(nèi)存管理等等;同時(shí)可以學(xué)習(xí)Nginx擴(kuò)展的開(kāi)發(fā),可以定制一些自己私有的擴(kuò)展;同時(shí)可以對(duì)Nginx+Lua有一定程度的了解,看看是否可以結(jié)合應(yīng)用出更好模式;這個(gè)階段的要求是對(duì)Nginx原理的深入理解,可以考慮成為Nginx方向的深入專(zhuān)業(yè)者。
3. MySQL/MongoDB: 在第二階段的基礎(chǔ)上面,在MySQL應(yīng)用方面,除了之前的基本SQL優(yōu)化,還能夠在完成一些復(fù)雜操作,比如大批量數(shù)據(jù)的導(dǎo)入導(dǎo)出,線上大批量數(shù)據(jù)的更改表結(jié)構(gòu)或者增刪索引字段等等高危操作;除了安裝配置,已經(jīng)能夠處理更多復(fù)雜的MySQL的問(wèn)題,比如各種問(wèn)題的追查,主從同步延遲問(wèn)題的解決、跨機(jī)房同步數(shù)據(jù)方案、MySQL高可用架構(gòu)等都有涉及了解;對(duì)MySQL應(yīng)用層面,對(duì)MySQL的核心關(guān)鍵技術(shù)比較熟悉,比如事務(wù)機(jī)制(隔離級(jí)別、鎖等)、對(duì)觸發(fā)器、分區(qū)等技術(shù)有一定了解和應(yīng)用;對(duì)MySQL性能方面,有包括磁盤(pán)優(yōu)化(SAS遷移到SSD)、服務(wù)器優(yōu)化(內(nèi)存、服務(wù)器本身配置)、除了二階段的其他核心性能優(yōu)化選項(xiàng)(innodb_log_buffer_size/back_log/table_open_cache/thread_cache_size/innodb_lock_wait_timeout等)、連接池軟件選擇應(yīng)用,對(duì)show *(show status/show profile)類(lèi)的操作語(yǔ)句有深入了解,能夠完成大部分的性能問(wèn)題追查;MySQL備份技術(shù)的深入熟悉,包括災(zāi)備還原、對(duì)Binlog的深入理解,冷熱備份,多IDC備份等;在MySQL原理方面,有更多了解,比如對(duì)MySQL的工作機(jī)制開(kāi)始閱讀部分源碼,比如對(duì)主從同步(復(fù)制)技術(shù)的源碼學(xué)習(xí),或者對(duì)某個(gè)存儲(chǔ)引擎(MyISAM/Innodb/TokuDB)等等的源碼學(xué)習(xí)理解,如果條件允許,可以參考CSV引擎開(kāi)發(fā)自己簡(jiǎn)單的存儲(chǔ)引擎來(lái)保存一些數(shù)據(jù),增強(qiáng)對(duì)MySQL的理解;在這個(gè)過(guò)程,如果自己有興趣,也可以考慮往DBA方向發(fā)展。MongoDB層面,可以考慮比如說(shuō)在寫(xiě)少讀多的情況開(kāi)始在線上應(yīng)用MongoDB,或者是做一些線上的數(shù)據(jù)分析處理的操作,具體場(chǎng)景可以按照工作來(lái),不過(guò)核心是要更好的深入理解RMDBS和NoSQL的不同場(chǎng)景下面的應(yīng)用,如果條件或者興趣允許,可以開(kāi)始深入學(xué)習(xí)一下MongoDB的工作機(jī)制。
4. Redis/Memcached: 在第二階段的基礎(chǔ)上面,能夠更深入的應(yīng)用和學(xué)習(xí)。因?yàn)镸emcached不是特別復(fù)雜,建議可以把源碼進(jìn)行閱讀,特別是內(nèi)存管理部分,方便深入理解;Redis部分,可以多做一些復(fù)雜的數(shù)據(jù)結(jié)構(gòu)的應(yīng)用(zset來(lái)做排行榜排序操作/事務(wù)處理用來(lái)保證原子性在秒殺類(lèi)場(chǎng)景應(yīng)用之類(lèi)的使用操作);多涉及aof等同步機(jī)制的學(xué)習(xí)應(yīng)用,設(shè)計(jì)一個(gè)高可用的Redis應(yīng)用架構(gòu)和集群;建議可以深入的學(xué)習(xí)一下Redis的源碼,把在第二階段積累的知識(shí)都可以應(yīng)用上,特別可以閱讀一下包括核心事件管理、內(nèi)存管理、內(nèi)部核心數(shù)據(jù)結(jié)構(gòu)等充分學(xué)習(xí)了解一下。如果興趣允許,可以成為一個(gè)Redis方面非常專(zhuān)業(yè)的使用者。
5. PHP: 作為基礎(chǔ)核心技能,我們?cè)诘诙A段的基礎(chǔ)上面,需要有更深入的學(xué)習(xí)和應(yīng)用。從基本代碼應(yīng)用上面來(lái)說(shuō),能夠解決在PHP開(kāi)發(fā)中遇到95%的問(wèn)題,了解大部分PHP的技巧;對(duì)大部分的PHP框架能夠迅速在一天內(nèi)上手使用,快速理解各種開(kāi)源網(wǎng)站源碼,并且了解各個(gè)主流PHP框架的優(yōu)缺點(diǎn),能夠迅速方便項(xiàng)目開(kāi)發(fā)中做技術(shù)選型;在配置方面,除了常規(guī)第二階段會(huì)的知識(shí),會(huì)了解一些比較偏門(mén)的配置選項(xiàng)(php auto_prepend_file/auto_append_file),包括擴(kuò)展中的一些復(fù)雜高級(jí)配置和原理(比如memcached擴(kuò)展配置中的memcache.hash_strategy、apc擴(kuò)展配置中的apc.mmap_file_mask/apc.slam_defense/apc.file_update_protection之類(lèi)的);對(duì)php的工作機(jī)制比較了解,包括php-fpm工作機(jī)制(比如php-fpm在不同配置機(jī)器下面開(kāi)啟進(jìn)程數(shù)量計(jì)算以及原理),對(duì)zend引擎有基本熟悉(vm/gc/stream處理),閱讀過(guò)基本的PHP內(nèi)核源碼(或者閱讀過(guò)相關(guān)文章),對(duì)PHP內(nèi)部機(jī)制的大部分核心數(shù)據(jù)結(jié)構(gòu)(基礎(chǔ)類(lèi)型/Array/Object)實(shí)現(xiàn)有了解,對(duì)于核心基礎(chǔ)結(jié)構(gòu)(zval/hashtable/gc)有深入學(xué)習(xí)了解;能夠進(jìn)行基本的PHP擴(kuò)展開(kāi)發(fā),了解一些擴(kuò)展開(kāi)發(fā)的中高級(jí)知識(shí)(minit/rinit等),熟悉php跟apache/nginx不同的通信交互方式細(xì)節(jié)(mod_php/fastcgi);除了開(kāi)發(fā)PHP擴(kuò)展,可以考慮學(xué)習(xí)開(kāi)發(fā)Zend擴(kuò)展,從更底層去了解PHP。
6. C/C++: 在第二階段基礎(chǔ)上面,能夠在C/C++語(yǔ)言方面有更深入的學(xué)習(xí)了解,能夠完成中小型C/C++系統(tǒng)的開(kāi)發(fā)工作;除了基本第二階段的基礎(chǔ)C/C++語(yǔ)法和數(shù)據(jù)結(jié)構(gòu),也能夠?qū)W習(xí)一些特殊數(shù)據(jù)結(jié)構(gòu)(b-tree/rb-tree/skiplist/lsm-tree/trie-tree等)方便在特殊工作中需求;在系統(tǒng)編程方面,熟悉多進(jìn)程、多線程編程;多進(jìn)程情況下面了解大部分多進(jìn)程之間的通信方式,能夠靈活選擇通信方式(共享內(nèi)存/信號(hào)量/管道等);多線程編程能夠良好的解決鎖沖突問(wèn)題,并且能夠進(jìn)行多線程程序的開(kāi)發(fā)調(diào)試工作;同時(shí)對(duì)網(wǎng)絡(luò)編程比較熟悉,了解多進(jìn)程模型/多線程模型/異步網(wǎng)絡(luò)IO模型的差別和選型,熟悉不同異步網(wǎng)絡(luò)IO模型的原理和差異(select/poll/epoll/iocp等),并且熟悉常見(jiàn)的異步框架(ACE/ICE/libev/libevent/libuv/Boost.ASIO等)和使用,如果閑暇也可以看看一些國(guó)產(chǎn)自己開(kāi)發(fā)的庫(kù)(比如muduo);同時(shí)能夠設(shè)計(jì)好的高并發(fā)程序架構(gòu)(leader-follow/master-worker等);了解大部分C/C++后端Server開(kāi)發(fā)中的問(wèn)題(內(nèi)存管理、日志打印、高并發(fā)、前后端通信協(xié)議、服務(wù)監(jiān)控),知道各個(gè)后端服務(wù)RPC通信問(wèn)題(struct/http/thirft/protobuf等);能夠更熟絡(luò)的使用GCC和GDB來(lái)開(kāi)發(fā)編譯調(diào)試程序,在線上程序core掉后能夠迅速追查跟蹤解決問(wèn)題;通用模塊開(kāi)發(fā)方面,可以積累或者開(kāi)發(fā)一些通用的工具或庫(kù)(比如異步網(wǎng)絡(luò)框架、日志庫(kù)、內(nèi)存池、線程池等),不過(guò)開(kāi)發(fā)后是否應(yīng)用要謹(jǐn)慎,省的埋坑去追bug;
7. 前端: 深入了解HTTP協(xié)議(包括各個(gè)細(xì)致協(xié)議特殊協(xié)議代碼和背后原因,比如302靜態(tài)文件緩存了,502是nginx后面php掛了之類(lèi)的);除了之前的前端方面的各種框架應(yīng)用整合能力,前端方面的學(xué)習(xí)如果有興趣可以更深入,表現(xiàn)形式是,可以自己開(kāi)發(fā)一些類(lèi)似jQuery的前端框架,或者開(kāi)發(fā)一個(gè)富文本編輯器之類(lèi)的比較瑣碎考驗(yàn)JavaScript功力;
8. 其他領(lǐng)域語(yǔ)言學(xué)習(xí): 在基礎(chǔ)的PHP/C/C++語(yǔ)言方面有基本積累,建議在當(dāng)前階段可以嘗試學(xué)習(xí)不同的編程語(yǔ)言,看個(gè)人興趣愛(ài)好,腳本類(lèi)語(yǔ)言可以學(xué)學(xué) Python/Ruby 之類(lèi)的,函數(shù)式編程語(yǔ)言可以試試 Lisp/Haskell/Scala/Erlang 之類(lèi)的,靜態(tài)語(yǔ)言可以試試 Java/Golang,數(shù)據(jù)統(tǒng)計(jì)分析可以了解了解R語(yǔ)言,如果想換個(gè)視角做后端業(yè)務(wù),可以試試 Node.js還有前面提到的跟Nginx結(jié)合的Nginx_Lua等。學(xué)習(xí)不同的語(yǔ)言主要是提升自己的視野和解決問(wèn)題手段的差異,比如會(huì)了解除了進(jìn)程/線程,還有輕量級(jí)協(xié)程;比如在跨機(jī)器通信場(chǎng)景下面,Erlang的解決方案簡(jiǎn)單的驚人;比如在不想選擇C/C++的情況下,還有類(lèi)似高效的Erlang/Golang可用等等;主要是提升視野。
9. 其他專(zhuān)業(yè)方向?qū)W習(xí): 在本階段里面,會(huì)除了基本的LNMP技能之外,會(huì)考慮一些其他領(lǐng)域知識(shí)的學(xué)習(xí),這些都是可以的,看個(gè)人興趣和長(zhǎng)期的目標(biāo)方向。目前情況能夠選擇的領(lǐng)域比較多,比如、云計(jì)算(分布式存儲(chǔ)、分布式計(jì)算、虛擬機(jī)等),機(jī)器學(xué)習(xí)(數(shù)據(jù)挖掘、模式識(shí)別等,應(yīng)用到統(tǒng)計(jì)、個(gè)性化推薦),自然語(yǔ)言處理(中文分詞等),搜索引擎技術(shù)、圖形圖像、語(yǔ)音識(shí)別等等。除了這些高大上的,也有很多偏工程方面可以學(xué)習(xí)的地方,比如高性能系統(tǒng)、移動(dòng)開(kāi)發(fā)(Android/IOS)、計(jì)算機(jī)安全、嵌入式系統(tǒng)、硬件等方向。
10. 系統(tǒng)設(shè)計(jì): 系統(tǒng)設(shè)計(jì)在第二階段的基礎(chǔ)之上,能夠應(yīng)用掌握的經(jīng)驗(yàn)技能,設(shè)計(jì)出比較復(fù)雜的中大型系統(tǒng),能夠解決大部分線上的各種復(fù)雜系統(tǒng)的問(wèn)題,完成類(lèi)似 瀏覽器 -> CDN -> 負(fù)載均衡 ->接入層 -> Nginx+PHP -> 業(yè)務(wù)緩存 -> 數(shù)據(jù)庫(kù) -> 各路復(fù)雜后端RPC交互(存儲(chǔ)后端、邏輯后端、反作弊后端、外部服務(wù)) -> 更多后端 醬紫的復(fù)雜業(yè)務(wù);能夠支撐每天數(shù)千萬(wàn)到數(shù)億流量網(wǎng)站的正常開(kāi)發(fā)維護(hù)工作。
|