最近兩個(gè)月一直在研究 Swoole,研究成果即將在6.21正式開(kāi)源發(fā)布办铡,這段時(shí)間沒(méi)有來(lái)水文章辞做,趁著今天放假來(lái)水水吧。
借助這篇文章寡具,我希望能夠把 Swoole 安利給更多人秤茅。雖然 Swoole 可能目前定位是一些高級(jí) phper 的玩具,讓中低級(jí)望而生畏童叠,可能對(duì)一些應(yīng)用場(chǎng)景也一臉懵逼框喳,但其實(shí)沒(méi)這么難的课幕。
在 Swoole 官網(wǎng)的自我介紹是“面向生產(chǎn)環(huán)境的 PHP 異步網(wǎng)絡(luò)通信引擎”,首先 Swoole 它是一個(gè)網(wǎng)絡(luò)應(yīng)用的開(kāi)發(fā)工具五垮,它支持 Http乍惊、TCP、UDP放仗、WebSocket润绎。
Swoole 和我們傳統(tǒng)的 PHP 開(kāi)發(fā)差別是有的,需要理解的概念也是有的诞挨。使用目前一些基于 Swoole 的框架開(kāi)發(fā)的話(huà)莉撇,從開(kāi)發(fā)習(xí)慣上和傳統(tǒng)的TP、LV 框架相差不多惶傻。
那為什么要使用 Swoole棍郎?
宇潤(rùn)認(rèn)為有以下幾點(diǎn):
常駐內(nèi)存,避免重復(fù)加載帶來(lái)的性能損耗达罗,提升海量性能
協(xié)程異步坝撑,提高對(duì) I/O 密集型場(chǎng)景并發(fā)處理能力(如:微信開(kāi)發(fā)、支付粮揉、登錄等)
方便地開(kāi)發(fā) Http巡李、WebSocket、TCP扶认、UDP 等應(yīng)用侨拦,可以與硬件通信
PHP 高性能微服務(wù)架構(gòu)成為現(xiàn)實(shí)
10年架構(gòu)師領(lǐng)你架構(gòu)-成長(zhǎng)之路-(附面試題(含答案))
(騰訊T3-T4)打造互聯(lián)網(wǎng)PHP架構(gòu)師教程目錄大全,只要你看完辐宾,薪資立馬提升2倍(持續(xù)更新)
常駐內(nèi)存
目前傳統(tǒng) PHP框架狱从,在處理每個(gè)請(qǐng)求之前,都要做一遍加載框架文件叠纹、配置的操作季研。這可能已經(jīng)成為性能問(wèn)題的一大原因,而使用 Swoole 則沒(méi)有這個(gè)問(wèn)題誉察,一次加載多次使用与涡。
協(xié)程
如下圖所示,這是同一個(gè)線(xiàn)程處理并發(fā)請(qǐng)求的場(chǎng)景持偏,比如你某個(gè)接口中需要調(diào)用其它 api 接口或讀寫(xiě)大文件驼卖,傳統(tǒng)同步阻塞和協(xié)程異步的優(yōu)勢(shì)就體現(xiàn)了出來(lái)。
[圖片上傳失敗...(image-3f5bfd-1600346322180)]
說(shuō)到協(xié)程鸿秆,就得先簡(jiǎn)單說(shuō)說(shuō)進(jìn)程和線(xiàn)程酌畜,眾所周知進(jìn)程是很占用資源的,為了處理請(qǐng)求大量創(chuàng)建進(jìn)程肯定是得不償失的卿叽。而多線(xiàn)程應(yīng)用就比較多了桥胞,在 CPU 層面有幾個(gè)核心就會(huì)執(zhí)行幾個(gè)任務(wù)恳守,線(xiàn)程一旦創(chuàng)建的多了,就會(huì)有線(xiàn)程調(diào)度的損耗埠戳。
協(xié)程是在單線(xiàn)程基礎(chǔ)上實(shí)現(xiàn)的井誉,它可以最大限度利用 CPU 資源,而不會(huì)在等待 I/O 時(shí)白白浪費(fèi)整胃。當(dāng)然颗圣,協(xié)程數(shù)越多占用的內(nèi)存也就越多,不過(guò)這個(gè)是可以接受的屁使,相比進(jìn)程和線(xiàn)程在岂,占用的資源是相對(duì)較少的。
使用協(xié)程時(shí)蛮寂,遇到讀寫(xiě)文件蔽午、請(qǐng)求接口等場(chǎng)景,會(huì)自動(dòng)掛起協(xié)程酬蹋,把 CPU 讓給其它協(xié)程執(zhí)行任務(wù)及老,這樣可以提升單線(xiàn)程的 CPU 資源利用率,減少浪費(fèi)范抓,從而提高性能骄恶。
感謝大家一直來(lái)支持,這是我準(zhǔn)備的1000粉絲福利
【1000粉絲福利】10年架構(gòu)師分享PHP進(jìn)階架構(gòu)資料匕垫,助力大家都能30K
協(xié)程代碼示例:
|
1234567891011121314151617181920212223242526
|
<?phpuse Swoole\Coroutine as co; // 協(xié)程i = 0;
i){ // 創(chuàng)建協(xié)程 go(function() use(
i, PHP_EOL; });}swoole_event_wait();echo 'co time:', microtime(true) -
time = microtime(true);// 創(chuàng)建10個(gè)協(xié)程for(
i < 10; ++
i, PHP_EOL;}echo 'sync time:', microtime(true) - $time, ' s', PHP_EOL;
|
運(yùn)行結(jié)果:
|
12345678910111213141516171819202122
|
0987654321co time:1.0087130069733 s0123456789sync time:10.010055065155 s
|
從上面結(jié)果可以看出象泵,協(xié)程方式執(zhí)行并不是順序的寞秃,性能更高,在sleep時(shí)會(huì)把當(dāng)前線(xiàn)程的任務(wù)執(zhí)行權(quán)交給其他協(xié)程偶惠。
創(chuàng)建 Http 服務(wù)
其實(shí)也沒(méi)想象中的難春寿,看代碼:
|
12345
|
http->on('request', function (
response) {
http->start();
|
微服務(wù)
Tars是騰訊從2008年到今天一直在使用的后臺(tái)邏輯層的統(tǒng)一應(yīng)用框架TAF(Total Application Framework),目前支持C++,Java,PHP,Nodejs語(yǔ)言忽孽。該框架為用戶(hù)提供了涉及到開(kāi)發(fā)堂淡、運(yùn)維、以及測(cè)試的一整套解決方案扒腕,幫助一個(gè)產(chǎn)品或者服務(wù)快速開(kāi)發(fā)、部署萤悴、測(cè)試瘾腰、上線(xiàn)。 它集可擴(kuò)展協(xié)議編解碼覆履、高性能RPC通信框架蹋盆、名字路由與發(fā)現(xiàn)费薄、發(fā)布監(jiān)控、日志統(tǒng)計(jì)栖雾、配置管理等于一體楞抡,通過(guò)它可以快速用微服務(wù)的方式構(gòu)建自己的穩(wěn)定可靠的分布式應(yīng)用,并實(shí)現(xiàn)完整有效的服務(wù)治理析藕。
大廠2000道面試題(含答案)
PHP面試題匯總召廷,看完這些面試題助力你面試成功,工資必有20-25K
喜歡我的文章就關(guān)注我吧账胧,持續(xù)更新中.....
以上內(nèi)容希望幫助到大家竞慢,很多PHPer在進(jìn)階的時(shí)候總會(huì)遇到一些問(wèn)題和瓶頸,業(yè)務(wù)代碼寫(xiě)多了沒(méi)有方向感治泥,不知道該從那里入手去提升筹煮,對(duì)此我整理了一些資料,包括但不限于:分布式架構(gòu)居夹、高可擴(kuò)展败潦、高性能、高并發(fā)准脂、服務(wù)器性能調(diào)優(yōu)劫扒、TP6,laravel意狠,YII2粟关,Redis,Swoole环戈、Swoft闷板、Kafka、Mysql優(yōu)化院塞、shell腳本遮晚、Docker、微服務(wù)拦止、Nginx等多個(gè)知識(shí)點(diǎn)高級(jí)進(jìn)階干貨需要的可以免費(fèi)分享給大家县遣,需要的可以點(diǎn)擊進(jìn)入暗號(hào):知乎。