PHP高效能框架適合負載併發
在不用快取、叢集之類東東只情況下,PHP框架哪家強?我指的是高併發高負載,並且適合做大型專案的。
高負載不是一個語言的問題,這個討論的範圍已經超出了PHP:
1、如果同一型別的的框架(指都是為了解決某類問題,比如CMS,論壇等乖)是比較成熟的,那麼在生產環境,大家的差異不會差不那裡去;
2、框架的最主要目的不是為了解決“負載”的問題,而是加速開發。
3、負載的問題,最直接的可以由硬體來完成,比如一個相對比較爛的程式,只有要足夠的資源,也可以比一個資源不足的程式跑得好;一個程式,先是考慮能否完成業務,再考慮其它的問題,會比較好一點;
4、框架本身也不一定就決定了負載,也決定於使用的人,比如框架提供的快取是否被正確的使用,框架提供的優化配置是否被合理的使用等等。
……
說了這麼多,其實想說:哪個框架熟悉就用哪個,真的等到負載出問題了,找你的老闆,相信他會有更好的解決方案。(負載出問題了,一定是到了要數錢的階段了)
決定能否高併發高負載的是你的業務型別和程式碼質量,和框架沒有太多關係。
大多數情況下業務的效能消耗是遠大於框架本身的消耗,除非你的業務只是簡單的CURD
效能好,簡單(c擴充套件的,PHP程式碼進行的都是間接的C呼叫,就像PHP的庫函式一樣.):
yaf 、Phalcon或者yii、laravel等國外龐大框架 基本上高效能並且輕量級軟體都C有關例如nginx和python等
PHP快取技術:Memcache技術、OPcache技術、accurlater技術和Varnish技術
Mysql和檔案快取技術:Redis和Nosql
要高併發,yaf實在是不合適。yar還稍微說的過去。
個人的建議是:swoole + apache thrift 或者推薦Phalcon 或者Swoole+Lumen 基於Swoole加速Lumen,開發效率和效能二者兼得。其他國內php內容管理系統都是渣渣。
Requirements
Dependency | Requirement |
---|---|
PHP | >= 5.5.9 Recommend PHP7+ |
Swoole | >= 1.7.19 No longer support PHP5 since 2.0.12 Recommend 4.2.3+ |
Laravel/Lumen | >= 5.1 Recommend 5.6+ |
Yaf的其實本質上講,是個基礎框架,僅提供了一個簡單粗暴的基礎URI路由功能,完事了。
最關鍵是併發和多執行緒以及定時器等等,Yaf本身不能實現。
所以swoole這個時候,優勢突顯。swoole可以以deamon形式長期穩定的執行在server上,直接走socket,提供併發服務。
而整合了thrift後,就可以為各種其他端提供資料。比如app,web網頁(這個時候,可以用yaf當作前端讀取資料提供高效能),甚至為C,c++等端進行資料互動,非常方便。
但是Yaf是鳥哥的成名作,要用框架又要追求高效能就用Yaf吧,據說百度內部用的也是Yaf的修改版或者thinkCMF,據說微博也用的yaf yar所以還是比較好的方案。可以用yaf,推薦搭建hhvm或者php7 。
用你最熟悉的框架就好
高併發主要關注兩點:
1,系統架構
2,業務邏輯 這個跟框架還算有點關係,不過關注點不在用什麼框架
系統架構
主要是考慮的負載, 網路請求支援,運維輕鬆搞定,商量好方案,慢慢加機器就好。
業務邏輯
這塊做為開發人員,要知道業務本身壓力是在資料庫讀寫,檔案讀寫
可以根據情況做快取方案 和 非同步處理方案
在真正的高併發下,程式邏輯本身和單點都會是瓶頸,做好負載均衡解決方案,才是支援無限增長高併發的終極解決方案
總結一下自己的認識:
- 只在程式層面考慮選型確實眼界不夠,因為開發、運維、業務是連在一起的。如果要求很高,可能還需要語言平臺上的考慮。
- 只需要考慮比較主流的框架,人民的眼睛是雪亮的。
- 功能和效能是互斥的,功能方面就是元件多,介面多,靈活性高,擴充套件性強,這些都需要硬體資源(cpu和記憶體)來支撐的,當然還要多點點的時間。所以很過分支版本是精簡版,可以考慮。
- 高併發高負載是運維上的事,程式只需要稍作配合,主要是分發和各級別的快取。
- 高併發高負載是需求的一個趨勢,但對好多專案來說這個需求超前了,等專案死的時候還沒有什麼人訪問。。
- 高併發本質和框架是無關的。。。框架只是封裝了一些元件,高併發還得看架構設計,非同步訊息佇列怎麼搞,快取怎麼搞,不能單單寄希望於框架,不然的話,最後你會發現加框架和不加框架會是一個效果。。
- 高併發的API效能取決於架構和快取以及資料庫!!!和框架沒任何關係!!!
- PHP 框架, 本來解決的問題就是開發效率, 相比 JAVA, C/C++ 來說, PHP 的執行效率夠慢的, 框架還是一堆程式碼構建於 PHP 之上, 所以追求極致效能的話, 不建議用 PHP 來做。一般java、Python和go能夠很好解決非同步和負載問題。
- io密集型的高併發應該用epoll模型將併發排程到io層,然後就是進行db的設計了,理論上跟cgi關係不大了。如果你說的是CPU密集型的高併發請忽略
高效能PHP框架 Phalcon
PhalconPHP 是一個使用 C 擴充套件開發的 PHP Web 框架,提供高效能和低資源佔用。
Phalcon 是一個開源的、全堆疊的 PHP 5 框架,使用 C 擴充套件編寫,專門為高效能優化。無需學習和使用 C 語言,所有函式都以 PHP 類的方式曾現。Phalcon 是一個鬆耦合的框架。
使用時需在 php.ini 中新增:extension=phalcon.so
Swoole高效能網路通訊引擎
Swoole是一個PHP擴充套件,擴充套件不是為了提升網站的效能,是為了提升網站的開發效率。最少的效能損耗,換取最大的開發效率。利用Swoole擴充套件,開發一個複雜的Web功能,可以在很短的時間內完成了。
——PHP的非同步、並行、高效能網路通訊引擎,支援TCP長連線,Websocket,Mqtt等協議。
PHP的協程高效能網路通訊引擎,使用C/C++
語言編寫,提供了PHP語言的非同步多執行緒伺服器,非同步TCP/UDP網路客戶端,非同步MySQL,非同步Redis,資料庫連線池,AsyncTask,訊息佇列,毫秒定時器,非同步檔案讀寫,非同步DNS查詢。 Swoole內建了Http/WebSocket伺服器端/客戶端、Http2.0伺服器端/客戶端。
Swoole4
支援完整的協程程式設計模式,可以使用完全同步的程式碼實現非同步程式。PHP
程式碼無需額外增加任何關鍵詞,底層自動進行協程排程,實現非同步IO
。
Swoole4
協程僅支援PHP7
,無法在PHP5
中使用
除了非同步IO的支援之外,Swoole
為PHP
多程式的模式設計了多個併發資料結構和IPC通訊機制,可以大大簡化多程式併發程式設計的工作。其中包括了併發原子計數器,併發HashTable,Channel,Lock,程式間通訊IPC等豐富的功能特性。
Swoole
可以廣泛應用於網際網路、行動通訊、企業軟體、網路遊戲、物聯網、車聯網、智慧家庭等領域。 使用PHP
+ Swoole
作為網路通訊框架,可以使企業IT
研發團隊的效率大大提升,更加專注於開發創新產品。
Swoole
是開源免費的自由軟體,授權協議是Apache2.0
,企業和個人開發者均可免費使用,並且在Swoole
之上所作的修改可用於商業產品,無需開源(注:必須保留原作者的版權宣告)。
Swoole不是一個像Zend Framework、CakePHP、Yii、symfony、ThinkPHP等一樣的框架,也不是一個像WordPress、Drupal、Discuz、UChome等開源產品看齊的專案。 Swoole的目標是向Java框架、Ruby On Rails、Python Django Pylons等一流框架發起挑戰。
執行環境:Linux Windows Mac FreeBSD Unix
PHP版本支援:PHP5.3+
支援的資料庫:MS SQL Server、MySQL、IBM DB2、Oracle、Interbase 、SQLite、PostgreSQL、ODBC
支援的執行方式:Web、Cli命令列指令碼、PHP-GTK GUI。
PHP四大主流框架的優缺點總結
ThinkPHP
ThinkPHP(FCS)是一個輕量級的中型框架,是從Java的Struts結構移植過來的中文PHP開發框架。它使用物件導向的開發結構和MVC模式,並且模擬實現了Struts的標籤庫,各方面都比較人性化,熟悉J2EE的開發人員相對比較容易上手,適合php框架初學者。 ThinkPHP的宗旨是簡化開發、提高效率、易於擴充套件,其在對資料庫的支援方面已經包括MySQL、MSSQL、Sqlite、PgSQL、 Oracle,以及PDO的支援。ThinkPHP有著豐富的文件和示例,框架的相容性較強,但是其功能有限,因此更適合用於中小專案的開發。
優點:
1.易於上手,有豐富的中文文件;
2.框架的相容性較強,PHP4和PHP5完全相容、完全支援UTF8等。
3. 適合用於中小專案的開發
缺點:
1.對Ajax的支援不是很好;
2.目錄結構混亂,需要花時間整理;
3.上手容易,但是深入學習較難。
Yii
Yii 是一個基於元件的高效能php框架,用於開發大型Web應用。Yii採用嚴格的OOP編寫,並有著完善的庫引用以及全面的教程。從 MVC,DAO/ActiveRecord,widgets,caching,等級式RBAC,Web服務,到主題化,I18N和L10N,Yii提供了 今日Web 2.0應用開發所需要的幾乎一切功能。事實上,Yii是最有效率的PHP框架之一。
優點:
純OOP
用於大規模Web應用
模型使用方便
開發速度快,執行速度也快。效能優異且功能豐富
使用命令列工具。
缺點:
對Model層的指導和考慮較少
文件例項較少
英文太多
要求PHP技術精通,OOP程式設計要熟練!
View並不是理想view,理想中的view可能只是html程式碼,不會涉及PHP程式碼。
CodeIgniter
優點:
Code Igniter推崇“簡單就是美”這一原則。沒有花哨的設計模式、沒有華麗的物件結構,一切都是那麼簡單。幾行程式碼就能開始執行,再加幾 行程式碼就可以進行輸出。可謂是“大道至簡”的典範。 配置簡單,全部的配置使用PHP指令碼來配置,執行效率高;具有基本的路由功能,能夠進行一定程度的路 由;具有初步的Layout功能,能夠製作一定程度的介面外觀;資料庫層封裝的不錯,具有基本的MVC功能. 快速簡潔,程式碼不多,執行效能高,框架簡 單,容易上手,學習成本低,文件詳細;自帶了很多簡單好用的library,框架適合小型應用.
缺點:
本身的實現不太理想。內部結構過於混亂,雖然簡單易用,但缺乏擴充套件能力。 把Model層簡單的理解為資料庫操作. 框架略顯簡單,只能夠滿足小型應用,略微不太能夠滿足中型應用需要.
評價:
總體來說,拿CodeIgniter來完成簡單快速的應用還是值得,同時能夠構造一定程度的layout,便於模板的複用,資料操作層來說封裝的不 錯,並且CodeIgniter沒有使用很多太複雜的設計模式,執行效能和程式碼可讀性上都不錯。至於附加的library 也還不錯,簡潔高效。
Lavarel 框架
優點:
Laravel 的設計思想是很先進的,非常適合應用各種開發模式TDD, DDD 和BDD,作為一個框
架,它準備好了一切,composer 是個php 的未來,沒有composer,PHP 肯定要走向沒落。
laravel 最大的特點和優秀之處就是集合了php 比較新的特性,以及各種各樣的設計模式,
Ioc 容器,依賴注入等。
缺點:
基於元件式的框架,所以比較臃腫
附錄其他php各大主流框架比較
Zend Framework
優點:
Zend Framework大量應用了PHP5中物件導向的新特徵:介面、異常、抽象類、SPL等等。這些東西的應用讓Zend Framework具有高度的模組化和靈活性。同時,因為嚴格遵循“針對介面程式設計”和“單一物件職責”等原則,讓Zend Framework很有希望成為一個出色的企業應用開發框架. 官方出品,自帶了非常多的library,框架本身使用了很多設計模式來編寫,架構上很優雅,執行效率中等;MVC設計,比較簡潔,具有路由功能,配置檔案比較強大(能夠處理XML和php INI),各種 library 很強大,是所有PHP框架中各種功能最全面的,包括它不僅是一個框架,更是一個大類庫(取代PEAR),這是它的主要特色;能夠直觀的支援除資料庫操作之外的Model層(比 CodeIgniter 和 CakePHP 強),並且能夠很輕易的使用Loader功能載入其他新增加的Class;Cache功能很強大,從前端Cache到後端Cache都支援,後端Cache支援Memcache、APC、SQLite、檔案等等方式;資料庫操作功能很強大,支援各種驅動(介面卡). 文件很全,在國內社群很成熟,並且目前不少Web 2.0網站在使用,學習成本中等.
缺點:
MVC功能完成比較弱,View層簡單實現(跟沒實現一樣),無法很強大的控制前端頁面. 沒有自動化指令碼,建立一個應用,包括入口檔案,全部必須自己手工構建,入門成本高. 對於簡單和小型的專案來說,Zend Framework不但不能提高開發效率。反而因為在框架中應用了大量物件導向設計和PHP5的新特徵,對開發者提出了更高的要求,間接增加了專案的開發成本。而對於較大的專案和企業應用,Zend Framework倒是一個不錯的基礎。但是作為一個很成熟的大型PHP框架來說,還需要一些努力.
評價:
作為官方出品的框架,Zend Framework的野心是可以預見的,想把其他框架擠走,同時封裝很多強大的類庫,能夠提供一站式的框架服務,並且他們的開發團隊很強大,完全足夠有能力開發很強大的產品出來,所以基本可以確定的是Zend Framework前途無量,如果花費更多的時間去完善框架。同樣的,Zend Framework架構本身也是比較優雅的,說明Zend官方是有很多高手的,設計理念上比較先進,雖然有一些功能實現的不夠完善,比如View層,自動化指令碼等等,這些都有賴於未來的升級。總體來說Zend Framework是最值得期待的框架,當然,你目前要投入你的專案中使用也是完全沒問題的。
CakePHP
優點:
CakePHP是最類似於RoR的框架,包括設計方式,資料庫操作的Active Record方式;設計層面很優雅,沒有自帶多餘的 library,所有的功能都是純粹的框架,執行效率還不錯;資料庫層的 hasOne, hasMany功能很強大,對於複雜業務處理比較合適,路由功能,配置功能還不錯,自動構建腳手架(scaffold)很強大,適合中型應用,基本實現過了MVC每一層,具有自動操作命令列指令碼功能. 文件比較全,在國內推廣的比較成功,大部分都知道CakePHP,學習成本中等.
缺點:
CakePHP非常嚴重的問題是把Model理解為資料庫層操作,嚴重影響了除了資料庫之外的操作能力. CakePHP的cache功能略顯薄弱,配置功能稍嫌弱;CakePHP不適合大型應用,只適合中型應用,小型應用來說略微的學習成本高了點.
評價:
總體來說CakePHP框架代表了PHP框架很重要的一個時代和代表,並且目前發揮著很重要的作用,不少自己寫的框架都模仿了CakePHP的方式,是個里程碑式的產品;CakePHP透露著RoR的敏捷開發方式和把資料庫操作認為是唯一Model的設計思想,作為開發快速應用和原型是絕好的工具;同樣,用來做Web2.0網站的開發框架,也是值得選擇的。
CodeIgniter
優點:
Code Igniter推崇“簡單就是美”這一原則。沒有花哨的設計模式、沒有華麗的物件結構,一切都是那麼簡單。幾行程式碼就能開始執行,再加幾行程式碼就可以進行輸出。可謂是“大道至簡”的典範。 配置簡單,全部的配置使用PHP指令碼來配置,執行效率高;具有基本的路由功能,能夠進行一定程度的路由;具有初步的Layout功能,能夠製作一定程度的介面外觀;資料庫層封裝的不錯,具有基本的MVC功能. 快速簡潔,程式碼不多,執行效能高,框架簡單,容易上手,學習成本低,文件詳細;自帶了很多簡單好用的library,框架適合小型應用.
缺點:
本身的實現不太理想。內部結構過於混亂,雖然簡單易用,但缺乏擴充套件能力。 把Model層簡單的理解為資料庫操作. 框架略顯簡單,只能夠滿足小型應用,略微不太能夠滿足中型應用需要.
評價:
總體來說,拿CodeIgniter來完成簡單快速的應用還是值得,同時能夠構造一定程度的layout,便於模板的複用,資料操作層來說封裝的不錯,並且CodeIgniter沒有使用很多太複雜的設計模式,執行效能和程式碼可讀性上都不錯。至於附加的library 也還不錯,簡潔高效。
Symfony
優點:
Symfony 是我瞭解的PHP框架中功能最強大的,而且我使用時間比較長,但是很多功能還是沒有挖掘出來;它完整實現了MVC三層,封裝了所有東西,包括 $POST,$GET 資料,異常處理,除錯功能,資料檢測;包含強大的快取功能,自動載入Class(這個功能很爽),強大的語言支援;具有很強大的view層操作,能夠零碎的包含單個多個檔案;非常強大的配置功能,使用yml配置能夠控制所有框架和程式執行行為,強大到讓人無語;能夠很隨意的定義各種自己的class,並且symfony能夠自動載入(auto load)這些class,能夠在程式中隨意呼叫;包含強大的多層級專案和應用管理:Project --> Application --> Module --> Action,能夠滿足一個專案下多個應用的需要,並且每層可以定義自己的類庫,配置檔案,layout;非常強大的命令列操作功能,包括建立專案、建立應用、建立模組、重新整理快取等等. Symfony絕對是開發大型複雜專案的首選,因為使用了Symfony,將大大節約開發成本,並且多人協作的時候,不會出現問題,在Project級別定義好基礎Class以後,任何模組都能夠重用,大大複用程式碼.
缺點:
Symfony最大的問題也在於使用了太多風格迥異的開源專案來組合成框架。由於Mojavi和Propel本身都相當複雜,因此Symfony的結構非常複雜,難以理解和學習。 快取功能無法控制,每次開發除錯總是快取,需要執行 symfony cc,symfony rc來清除和重建快取. 效率不是很高,特別是解析模板和讀取配置檔案的過程,花費時間不少. 學習成本很高,並且國內沒有成熟的社群和文件,連中文手冊都沒有,相應的要掌握所有功能,需要花費比較多的時間.
評價:
Symfony絕對是企業級的框架,唯一能夠貌似能夠跟Java領域哪些強悍框架抗衡的東西;強悍的東西,自然學習複雜,但是相應的對專案開發也比較有幫助,自然是推薦複雜的專案使用Symfony來處理,覺得是值得,後期的維護成本比較低,複用性很強。相應的如果使用Symfony的應該都是比較複雜的網際網路專案,那麼相應的就要考慮關於資料庫分佈的問題,那麼就需要拋棄Symfony自帶的資料庫操作層,需要自己定義,當然了,Symfony支援隨意的構造model層。
ThinkPHP
ThinkPHP快速、借用了成熟的Java思想,但是實際使用呢過程中有些基本的CURD的關聯操作居然存在錯誤。ThinkPHP基於PHP5,充分利用了PHP5的特性。讓我十分喜歡的是ThinkPHP的資料驗證和自動填充。但是這個也束縛了ThinkPHP導致不考慮新增自動統計欄位等小功能.
ThinkPHP還有一個特性是從自動生成資料,但是這個卻不支援關聯。唉,ThinkPHP有著十分優秀的特性和思想,卻有著很一般的應用實踐體驗。 ThinkPHP的文件號稱最豐富,事實也是這樣,但是ThinkPHP的文件和示例卻又太泛泛,比如表關聯只介紹了其在model裡面的定義,其他的CURD操作都沒有提及。
FleaPHP
FleaPHP是一個採用PHP開發(完全支援 PHP4和PHP5)的應用程式框架,為開發者建立自己的應用程式提供了必要的基礎功能和輔助元件。它成熟、快速、功能豐富。但在一些細節上不如ThinkPHP人性化。如url函式。在FleaPHP中url函式的前兩個引數是控制器,動作名 ,而ThinkPHP恰好相反,因為只輸入動作名的情況很多。而且資料庫的操作上這種引數的安排也是沒有ThinkPHP人性化。FleaPHP對資料的操作很強大,居然可以操作中間表。FleaPHP的文件和示例極少,學習成本大。但是一上手之後就很簡單了。 FleaPHP框架的核心非常小,但通過靈活的配置,可以組合出各種型別的基礎架構。對於簡單的指令碼頁面,FleaPHP不需要載入MVC模式,只需 要為應用程式提供業務邏輯和資料庫服務。而對於複雜的應用程式,FleaPHP可以完成從MVC模式呼叫、訪問控制、資料驗證到檔案上傳、圖片處理等各種 各樣的任務。正是因為這種出色的定製和擴充套件能力,FleaPHP真正接近了“滿足從簡單應用到企業開發的各種需求”這個目標。而且與許多其他框架不 同,FleaPHP是一個完全在實際開發中精煉出來的框架。 FleaPHP作為一個完全國產的框架,具有完全中文化的文件、程式碼註釋,並且在擴充套件功能上也注重考慮國內開發者的實際需求。因此相對於國外的各種框架,FleaPHP更容易被國內開發者所接受。
總評:
以上數款框架,各有特色,而且都是開源專案,不過框架針對的專案不一樣,一般來說 CodeIngiter 比較適合小型專案,CakePHP和Zend Framework比較適合中型專案,Symfony比較適合大型重量級專案,在專案選型的時候,要充分考慮框架的可以定製性、擴充套件性,因為每個專案都無法確定你是否會隨著需求的變化進行改變。
相對來說,Zend Framework和Symfony應對變化的能力比較強,特別是能夠隨意定製model層的Class,能夠非常方便增加自己業務或者資料處理類,我是個人比較推薦在中大型專案中使用的框架。CodeIngiter和CakePHP在中小型專案中同樣能夠發揮重大作用,快速開發和原型構建,非常適合目標不清晰的原型專案的開發。ThinkPHP框架是國內比較優秀的框架,功能強大,學習起來容易。其靈活設計秉承簡單的理念。如果太注重效率就使用FleaPHP。
【參考資料】高併發高負載系統架構-php篇 - https://www.cnblogs.com/grimm/p/5211389.html
相關文章
- 如何選擇適合RCD負載箱負載
- 怎樣選擇適合自己php框架PHP框架
- PHP合併PDFPHP
- Disruptor 高效能併發框架二次封裝框架封裝
- 初試Gevent – 高效能的Python併發框架Python框架
- PHP 圖片的合併,微信小程式碼合併,文字合併PHP微信小程式
- PHP開發高負載網站技術PHP負載網站
- 徒手擼框架--高併發環境下的請求合併框架
- web開發|如何選擇合適的webui框架WebUI框架
- 如何合併視訊?是否適合新手操作?
- php列印負載函式、Linux awk列印負載PHP負載函式Linux
- 高可用+高併發+負載均衡架構設計負載架構
- 併發框架框架
- HAProxy高效能軟負載均衡器負載
- 極簡,高效能分散式 PHP 框架分散式PHP框架
- [分散式][高併發]負載均衡方案和演算法分散式負載演算法
- 這麼多TiDB負載均衡方案總有一款適合你TiDB負載
- php---空合併運算子PHP
- DPVS - 小米高效能負載均衡器負載
- Light-PHP 基於 swoole 的高效能 PHP 框架PHP框架
- PHP檔案及執行(適合PHP初學者)PHP
- 適合AI訓練的遊戲框架AI遊戲框架
- MySQL Proxy 實現 MySQL 讀寫分離提高併發負載MySql負載
- db4o適合負載均衡應用下的問題解決嗎負載
- 併發容器與框架——併發容器(二)框架
- webmen等框架真的比php-fpm併發數高嗎?Web框架PHP
- 十個最適合 Web 和 APP 開發的 NodeJS 框架WebAPPNodeJS框架
- 10 個最適合 Web 和 APP 開發的 NodeJS 框架WebAPPNodeJS框架
- 說說大型高併發高負載網站的系統架構(轉載)負載網站架構
- 啟發式合併
- Yii1.1.4釋出,高效能的PHP框架PHP框架
- 這才是 PHP 高效能框架 Workerman 的立命之本PHP框架
- 《高效能MySQL》筆記-併發控制MySql筆記
- 基於協程的高效能高併發伺服器框架—協程模組伺服器框架
- php合併陣列的幾種方式PHP陣列
- iOS App 開發的那些事兒 2:如何搭建合適的框架iOSAPP框架
- 高效能網站實用技巧之負載均衡篇網站負載
- 巨型專案如何選擇合適的框架?框架