中進階PHP程式員應該掌握哪些技術?

來源:互聯網
上載者:User

標籤:類型   tree   鏈表   nod   redis   知識   nginx   php物件導向   效能測試   

本文出處:http://www.jb51.net/article/93317.htm

本文把php程式員劃分為中、進階程式員兩大類程式員,並針對這兩大程式員應具備的技能進行分類探索。

中級PHP程式員 

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,還能夠承擔Proxy 伺服器、反向靜態伺服器等配置;知道基本的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. 系統設計:

 能夠設計大部分中型系統的網站架構、資料庫、基本PHP架構選型;效能測試排查處理等;能夠完成類似:瀏覽 器 -> CDN(Squid) -> Nginx+PHP -> 緩衝 -> 資料庫 結構網站的基本設計開發維護;能夠支撐 每天數百萬到千萬流量基本網站的開發維護工作; 

進階PHP程式員

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

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

1. Linux:

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

2. Nginx:

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

3. MySQL/MongoDB:

 在第二階段的基礎上面,在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的工作機制。 

4. Redis/Memcached:

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

5. PHP:

 作為基礎核心技能,我們在第二階段的基礎上面,需要有更深入的學習和應用。從基本代碼應用上面來說,能夠解決在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。

6. C/C++:

 在第二階段基礎上面,能夠在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;

7. 前端:

 深入瞭解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. 系統設計:

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

中進階PHP程式員應該掌握哪些技術?

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.