中級(jí)PHP程序員
1.Linux
能夠流暢的使用 Shell 腳本來完成很多自動(dòng)化的工作;awk/sed/perl 也操作的不錯(cuò),能夠完成很多文本處理和數(shù)據(jù)統(tǒng)計(jì)等工作;基本能夠安裝大 部分非特殊的 Linux 程序(包括各種庫、包、第三方依賴等等,比如 MongoDB/Redis/Sphinx/Luncene/SVN 之類的);了解基 本的 Linux 服務(wù),知道如何查看 Linux 的性能指標(biāo)數(shù)據(jù),知道基本的 Linux 下面的問題跟蹤等
2. Nginx:
在第一階段的基礎(chǔ)上面,了解復(fù)雜一些的 Nginx 配置;包括多核配置、events、proxy_pass,sendfile/tcp_*配置,知道超 時(shí)等相關(guān)配置和性能影響;知道 nginx 除了 web server,還能夠承擔(dān)代理服務(wù)器、反向靜態(tài)服務(wù)器等配置;知道基本的 nginx 配置調(diào)優(yōu);知道如 何配置權(quán)限、編譯一個(gè) nginx 擴(kuò)展到 nginx;知道基本的 nginx 運(yùn)行原理(master/worker 機(jī)制,epoll),知道為什么 nginx 性能比 apache 性能好等知識(shí);
3. MySQL/MongoDB:
在第一階段的基礎(chǔ)上面,在 MySQL 開發(fā)方面,掌握很多小技巧,包括常規(guī) SQL 優(yōu)化(group by/order by/rand 優(yōu)化等);除了能夠搭 建 MySQL,還能夠冷熱備份 MySQL 數(shù)據(jù),還知道影響 innodb/myisam 性能的配置選項(xiàng)(比如key_buffer/query_cache /sort_buffer/innodb_buffer_pool_size/innodb_flush_log_at_trx_commit等),也知 道這些選項(xiàng)配置成為多少值合適;另外也了解一些特殊的配置選項(xiàng),比如 知道如何搭建 mysql 主從同步的環(huán)境,知道各個(gè) binlog_format 的區(qū) 別;知道MySQL的性能追查,包括 slow_log/explain 等,還能夠知道基本的索引建立處理等知識(shí);原理方面了解基本的 MySQL 的架構(gòu) (Server+存儲(chǔ)引擎),知道基本的 InnoDB/MyISAM 索引存儲(chǔ)結(jié)構(gòu)和不同(聚簇索引,B樹);知道基本的 InnoDB 事務(wù)處理機(jī)制;了解大 部分 MySQL 異常情況的處理方案(或者知道哪兒找到處理方案)。條件允許的情況,建議了解一下 NoSQL 的代表 MongoDB 數(shù)據(jù)庫,順便對(duì)比跟 MySQL 的差別,同事能夠在合適的應(yīng)用場(chǎng)景安全謹(jǐn)慎的使用 MongoDB,知道基本的 PHP 與 MongoDB 的結(jié)合開發(fā)。
4. Redis/Memcached:
在大部分中型系統(tǒng)里面一定會(huì)涉及到緩存處理,所以一定要了解基本的緩存;知道 Memcached 和 Redis 的異同和應(yīng)用場(chǎng)景,能夠獨(dú)立安 裝 Redis/Memcached,了解 Memcahed 的一些基本特性和限制,比如最大的 value 值,知道PHP跟他們的使用結(jié)合;Redis了解 基本工作原理和使用,了解常規(guī)的數(shù)據(jù)類型,知道什么場(chǎng)景應(yīng)用什么類型,了解 Redis 的事務(wù)等等。原理部分,能夠大概了解Memcached 的內(nèi)存結(jié)構(gòu) (slab機(jī)制),redis就了解常用數(shù)據(jù)類型底層實(shí)現(xiàn)存儲(chǔ)結(jié)構(gòu)(SDS/鏈表/SkipList/HashTable)等等,順便了解一下 Redis 的事務(wù)、RDB、AOF 等機(jī)制更好
5. PHP:
除了第一階段的能力,安裝配置方面能夠隨意安裝 PHP 和各種第三方擴(kuò)展的編譯安裝配置;了解 php-fpm 的大部分配置選項(xiàng)和含義(如 max_requests/max_children/request_terminate_timeout 之類的影響性能的配置),知道 mod_php /fastcgi 的區(qū)別;在 PHP方面已經(jīng)能夠熟練各種基礎(chǔ)技術(shù),還包括各種深入些的 PHP,包括對(duì) PHP 面向?qū)ο蟮纳钊肜斫?SPL/語法層面的特殊特 性比如反射之類的;在框架方面已經(jīng)閱讀過最少一個(gè)以上常規(guī) PHP MVC 框架的代碼了,知道基本PHP框架內(nèi)部實(shí)現(xiàn)機(jī)制和設(shè)計(jì)思想;在 PHP 開發(fā)中已經(jīng)能 夠熟練使用常規(guī)的設(shè)計(jì)模式來應(yīng)用開發(fā)(抽象工廠/單例/觀察者/命令鏈/策略/適配器 等模式);建議開發(fā)自己的 PHP MVC 框架來充分讓開發(fā)自由化, 讓自己深入理解 MVC 模式,也讓自己能夠在業(yè)務(wù)項(xiàng)目開發(fā)里快速升級(jí);熟悉 PHP 的各種代碼優(yōu)化方法,熟悉大部分PHP安全方面問題的解決處理;熟悉基本的 PHP 執(zhí)行的機(jī)制原理(Zend 引擎/擴(kuò)展基本工作機(jī)制);
6. 系統(tǒng)設(shè)計(jì):
能夠設(shè)計(jì)大部分中型系統(tǒng)的網(wǎng)站架構(gòu)、數(shù)據(jù)庫、基本 PHP 框架選型;性能測(cè)試排查處理等;能夠完成類似:瀏覽器 -> CDN(Squid) -> Nginx+PHP -> 緩存 -> 數(shù)據(jù)庫 結(jié)構(gòu)網(wǎng)站的基本設(shè)計(jì)開發(fā)維護(hù);能夠支撐 每天數(shù)百萬到千萬流量基本網(wǎng)站的開發(fā)維護(hù)工作;
高級(jí)PHP程序員
重點(diǎn):除了基本的 LNMP 程序,還能夠在某個(gè)方向或領(lǐng)域有深入學(xué)習(xí)。(縱深維度發(fā)展)
目標(biāo):除了能夠完成基本的 PHP 業(yè)務(wù)開發(fā),還能夠解決大部分深入復(fù)雜的技術(shù)問題,并且可以獨(dú)立設(shè)計(jì)完成中大型的系統(tǒng)設(shè)計(jì)和開發(fā)工作;自己能夠獨(dú)立 hold 深入某個(gè)技術(shù)方向,在這塊比較專業(yè)。(比如在 MySQL、Nginx、PHP、Redis 等等任一方向深入研究)
1. Linux:
除了第二階段的能力,在 Linux 下面除了常規(guī)的操作和性能監(jiān)控跟蹤,還能夠使用很多高級(jí)復(fù)雜的命令完成工作(watch/tcpdump/starce /ldd/ar等);在 shell 腳本方面,已經(jīng)能夠編寫比較復(fù)雜的 shell 腳本(超過500行)來協(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、磁盤管理等等;
2. Nginx:
在第二階段的基礎(chǔ)上面,已經(jīng)能夠把 Nginx 操作的很熟練,能夠?qū)?Nginx 進(jìn)行更深入的運(yùn)維工作,比如監(jiān)控、性能優(yōu)化,復(fù)雜問題處理等等;看個(gè)人興趣, 更多方面可以考慮側(cè)重在關(guān)于 Nginx 工作原理部分的深入學(xué)習(xí),主要表現(xiàn)在閱讀源碼開始,比如具體的master/worker 工作機(jī)制,Nginx 內(nèi)部 的事件處理,內(nèi)存管理等等;同時(shí)可以學(xué)習(xí) Nginx 擴(kuò)展的開發(fā),可以定制一些自己私有的擴(kuò)展;同時(shí)可以對(duì) Nginx+Lua 有一定程度的了解,看看是否可 以結(jié)合應(yīng)用出更好模式;這個(gè)階段的要求是對(duì) Nginx 原理的深入理解,可以考慮成為 Nginx 方向的深入專業(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 的問題,比如各種問題的追查,主從同步延遲問題的解決、跨機(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 性能方面,有包括磁盤優(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)類的操作語句有深入了解,能夠完成大部分的性能問題追查;MySQL 備份技術(shù)的深入熟悉,包括災(zāi)備 還原、對(duì) Binlog 的深入理解,冷熱備份,多 IDC 備份等;在 MySQL 原理方面,有更多了解,比如對(duì) MySQL 的工作機(jī)制開始閱讀部分源碼,比如對(duì)主 從同步(復(fù)制)技術(shù)的源碼學(xué)習(xí),或者對(duì)某個(gè)存儲(chǔ)引擎(MyISAM/Innodb/TokuDB)等等的源碼學(xué)習(xí)理解,如果條件允許,可以參考 CSV 引擎 開發(fā)自己簡(jiǎn)單的存儲(chǔ)引擎來保存一些數(shù)據(jù),增強(qiáng)對(duì) MySQL 的理解;在這個(gè)過程,如果自己有興趣,也可以考慮往 DBA 方向發(fā)展。MongoDB 層面,可以考 慮比如說在寫少讀多的情況開始在線上應(yīng)用 MongoDB,或者是做一些線上的數(shù)據(jù)分析處理的操作,具體場(chǎng)景可以按照工作來,不過核心是要更好的深入理解 RMDBS 和 NoSQL 的不同場(chǎng)景下面的應(yīng)用,如果條件或者興趣允許,可以開始深入學(xué)習(xí)一下 MongoDB 的工作機(jī)制。
4. Redis/Memcached:
在第二階段的基礎(chǔ)上面,能夠更深入的應(yīng)用和學(xué)習(xí)。因?yàn)?Memcached 不是特別復(fù)雜,建議可以把源碼進(jìn)行閱讀,特別是內(nèi)存管理部分,方便深入理 解;Redis 部分,可以多做一些復(fù)雜的數(shù)據(jù)結(jié)構(gòu)的應(yīng)用(zset 來做排行榜排序操作/事務(wù)處理用來保證原子性在秒殺類場(chǎng)景應(yīng)用之類的使用操作);多涉及 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 方面非常專業(yè)的使用者。
5. PHP:
作為基礎(chǔ)核心技能,我們?cè)诘诙A段的基礎(chǔ)上面,需要有更深入的學(xué)習(xí)和應(yīng)用。從基本代碼應(yīng)用上面來說,能夠解決在 PHP 開發(fā)中遇到 95% 的問題,了解大部分 PHP 的技巧;對(duì)大部分的 PHP 框架能夠迅速在一天內(nèi)上手使用,并且了解各個(gè)主流 PHP 框架的優(yōu)缺點(diǎn),能夠迅速方便項(xiàng)目開發(fā)中做技術(shù)選型;在配置方面,除 了常規(guī)第二階段會(huì)的知識(shí),會(huì)了解一些比較偏門的配置選項(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 之類的);對(duì)php的 工作機(jī)制比較了解,包括 php-fpm 工作機(jī)制(比如 php-fpm 在不同配置機(jī)器下面開啟進(jìn)程數(shù)量計(jì)算以及原理),對(duì) zend 引擎有基本熟悉 (vm/gc/stream 處理),閱讀過基本的 PHP 內(nèi)核源碼(或者閱讀過相關(guān)文章),對(duì)PHP內(nèi)部機(jī)制的大部分核心數(shù)據(jù)結(jié)構(gòu)(基礎(chǔ)類型/Array /Object)實(shí)現(xiàn)有了解,對(duì)于核心基礎(chǔ)結(jié)構(gòu)(zval/hashtable/gc)有深入學(xué)習(xí)了解;能夠進(jìn)行基本的 PHP 擴(kuò)展開發(fā),了解一些擴(kuò)展開發(fā) 的中高級(jí)知識(shí)(minit/rinit等),熟悉 php 跟 apache/nginx 不同的通信交互方式細(xì)節(jié)(mod_php/fastcgi);除了開發(fā) PHP擴(kuò)展,可以考慮學(xué)習(xí)開發(fā) Zend 擴(kuò)展,從更底層去了解 PHP。
6. C/C++:
在第二階段基礎(chǔ)上面,能夠在 C/C++語言方面有更深入的學(xué)習(xí)了解,能夠完成中小型 C/C++系統(tǒng)的開發(fā)工作;除了基本第二階段的基礎(chǔ) C/C++語法和數(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)量/管道等);多線 程編程能夠良好的解決鎖沖突問題,并且能夠進(jìn)行多線程程序的開發(fā)調(diào)試工作;同時(shí)對(duì)網(wǎng)絡(luò)編程比較熟悉,了解多進(jìn)程模型/多線程模型/異步網(wǎng)絡(luò) IO 模型的差別 和選型,熟悉不同異步網(wǎng)絡(luò) IO 模型的原理和差異(select/poll/epoll/iocp等),并且熟悉常見的異步框架(ACE/ICE /libev/libevent/libuv/Boost.ASIO等)和使用,如果閑暇也可以看看一些國(guó)產(chǎn)自己開發(fā)的庫(比如muduo);同時(shí)能夠設(shè) 計(jì)好的高并發(fā)程序架構(gòu)(leader-follow/master-worker等);了解大部分 C/C++后端 Server 開發(fā)中的問題(內(nèi)存管理、日 志打印、高并發(fā)、前后端通信協(xié)議、服務(wù)監(jiān)控),知道各個(gè)后端服務(wù) RPC 通信問題(struct/http/thirft/protobuf等);能夠更熟 絡(luò)的使用 GCC 和 GDB 來開發(fā)編譯調(diào)試程序,在線上程序 core 掉后能夠迅速追查跟蹤解決問題;通用模塊開發(fā)方面,可以積累或者開發(fā)一些通用的工具或庫 (比如異步網(wǎng)絡(luò)框架、日志庫、內(nèi)存池、線程池等),不過開發(fā)后是否應(yīng)用要謹(jǐn)慎,省的埋坑去追bug;
7. 前端:
深入了解 HTTP 協(xié)議(包括各個(gè)細(xì)致協(xié)議特殊協(xié)議代碼和背后原因,比如302靜態(tài)文件緩存了,502是 nginx 后面 php 掛了之類的);除了之前的前端 方面的各種框架應(yīng)用整合能力,前端方面的學(xué)習(xí)如果有興趣可以更深入,表現(xiàn)形式是,可以自己開發(fā)一些類似 jQuery的前端框架,或者開發(fā)一個(gè)富文本編輯器 之類的比較瑣碎考驗(yàn) JavaScript 功力;
8. 其他領(lǐng)域語言學(xué)習(xí):
在基礎(chǔ)的 PHP/C/C++ 語言方面有基本積累,建議在當(dāng)前階段可以嘗試學(xué)習(xí)不同的編程語言,看個(gè)人興趣愛好,腳本類語言可以學(xué)學(xué) Python /Ruby 之類的,函數(shù)式編程語言可以試試 Lisp/Haskell/Scala/Erlang 之類的,靜態(tài)語言可以試試 Java /Golang,數(shù)據(jù)統(tǒng)計(jì)分析可以了解了解R語言,如果想換個(gè)視角做后端業(yè)務(wù),可以試試 Node.js 還有前面提到的跟Nginx結(jié)合的 Nginx_Lua 等。學(xué)習(xí)不同的語言主要是提升自己的視野和解決問題手段的差異,比如會(huì)了解除了進(jìn)程/線程,還有輕量級(jí)協(xié)程;比如在跨機(jī)器通信場(chǎng)景下 面,Erlang的解決方案簡(jiǎn)單的驚人;比如在不想選擇 C/C++的情況下,還有類似高效的 Erlang/Golang 可用等等;主要是提升視野。
9. 其他專業(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è)性化推薦),自然語言處理(中文分詞等),搜索 引擎技術(shù)、圖形圖像、語音識(shí)別等等。除了這些高大上的,也有很多偏工程方面可以學(xué)習(xí)的地方,比如高性能系統(tǒng)、移動(dòng)開發(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)的問題,完成類似 瀏覽 器 -> CDN -> 負(fù)載均衡 ->接入層 -> Nginx+PHP -> 業(yè)務(wù)緩存 -> 數(shù)據(jù) 庫 -> 各路復(fù)雜后端 RPC 交互(存儲(chǔ)后端、邏輯后端、反作弊后端、外部服務(wù)) -> 更多后端 醬紫的復(fù)雜業(yè)務(wù);能夠支撐每天數(shù)千萬到數(shù) 億流量網(wǎng)站的正常開發(fā)維護(hù)工作。
下圖總結(jié)的比較細(xì)致,從基礎(chǔ)到高級(jí)都有相應(yīng)的介紹,大家可以保存圖片仔細(xì)研究
推薦好課:PHP入門篇:十天學(xué)會(huì)PHP、PHP微課