進(jìn)程基本概念
狹義定義:進(jìn)程是正在運(yùn)行的程序的實(shí)例(an instance of a computer program that is being executed)。
對于一個(gè)進(jìn)程來說豺旬,它最核心的內(nèi)容可以分為兩個(gè)部分逝薪。第一個(gè)是它的內(nèi)存舀患,另一個(gè)部分是它的上下文環(huán)境贪惹。
在操作系統(tǒng)當(dāng)中炊苫,是可以運(yùn)行多個(gè)進(jìn)程的容达。對于一個(gè)進(jìn)程來說古涧,它可以調(diào)用系統(tǒng)函數(shù)來創(chuàng)建子進(jìn)程。如下圖所示:
需要注意的是:
- 子進(jìn)程會復(fù)制父進(jìn)程的內(nèi)存空間和上下文環(huán)境
- 修改某個(gè)子進(jìn)程的內(nèi)存空間花盐,不會修改父進(jìn)程或其他子進(jìn)程的內(nèi)存空間
Swoole本身也是一個(gè)多進(jìn)程的模型羡滑,它有多個(gè)worker進(jìn)程和自己的master進(jìn)程,多個(gè)worker進(jìn)程之間創(chuàng)建的變量是不會通用的算芯。
進(jìn)程間通訊
進(jìn)程間通訊的方式有很多種柒昏,其中一種是共享內(nèi)存。共享內(nèi)存是操作系統(tǒng)當(dāng)中一種比較特殊的內(nèi)存熙揍,它并不屬于任何進(jìn)程职祷,也不需要依賴于進(jìn)程而存在〗烨簦可以調(diào)用系統(tǒng)函數(shù)來創(chuàng)建一片共享內(nèi)存有梆,并指定它的索引,通過索引意系,任何一個(gè)進(jìn)程都可以在這片內(nèi)存空間申請內(nèi)存空間并在儲存一定值泥耀。
要點(diǎn):
- 共享內(nèi)存不屬于任何一個(gè)進(jìn)程
- 在共享內(nèi)存中分配的內(nèi)存空間可以被任何進(jìn)程訪問
- 即使進(jìn)程關(guān)閉,共享內(nèi)存仍然可以繼續(xù)保留
提示:可以使用命令ipcs -m
來查看共享內(nèi)存
Swoole 結(jié)構(gòu)
在過去用PHP寫web應(yīng)用蛔添,是需要依賴于nginx這樣的web服務(wù)器和php-fpm解析的痰催。php-fpm同樣也是一個(gè)多進(jìn)程的php解析器,當(dāng)一個(gè)請求過來的時(shí)候迎瞧,php-fpm會創(chuàng)建一個(gè)新的進(jìn)程來處理這個(gè)請求夸溶,這樣很大程度上系統(tǒng)開銷是用于創(chuàng)建和銷毀進(jìn)程,導(dǎo)致整個(gè)程序的響應(yīng)效率并不是非常的高凶硅。swoole和php-fpm采用了完全不同的架構(gòu)缝裁,如下圖所示:
整個(gè)swoole擴(kuò)展可分為三層。第一層master進(jìn)程足绅,這個(gè)進(jìn)程是swoole的主進(jìn)程压语。這個(gè)進(jìn)程是用于處理swoole核心的時(shí)間驅(qū)動的。在這個(gè)進(jìn)程當(dāng)中擁有若干個(gè)reactor線程编检,在每一個(gè)子線程當(dāng)中都運(yùn)行了epoll函數(shù)的實(shí)例胎食,swoole所有的對于事件的監(jiān)聽都會在這些線程當(dāng)中實(shí)現(xiàn)。
第二層是manager進(jìn)程允懂,這是一個(gè)管理進(jìn)程厕怜,用于創(chuàng)建管理下一次的woker進(jìn)程和task worker進(jìn)程。
第三層是工作進(jìn)程蕾总,分為兩個(gè)類型粥航,一類是worker進(jìn)程,這是主邏輯進(jìn)程生百,用于處理來自客戶端的請求递雀。另一類是task worker進(jìn)程,是異步工作進(jìn)程蚀浆,主要用于處理一些耗時(shí)較長的同步任務(wù)缀程。
整個(gè)響應(yīng)的流程如下:
當(dāng)一個(gè)新的客戶端連接來到時(shí)搜吧,首先會被main reactor接收到,然后將這個(gè)連接的讀寫操作監(jiān)聽注冊到對應(yīng)的reactor線程當(dāng)中杨凑,并通知worker進(jìn)程處理對應(yīng)onConnect的回調(diào)滤奈。
當(dāng)客戶端發(fā)送數(shù)據(jù)之后,reactor線程會收到這些數(shù)據(jù)撩满,并通過管道發(fā)送給worker進(jìn)行處理蜒程。
worker進(jìn)程如果需要投遞任務(wù),它就會通過管道或者消息隊(duì)列(可以配置)發(fā)送給task worker進(jìn)程伺帘。task worker進(jìn)程處理完成之后昭躺,返回給worker,worker通知reactor線程發(fā)送數(shù)據(jù)給客戶端伪嫁。
當(dāng)worker進(jìn)程出現(xiàn)意外领炫,或者處理一定次數(shù)的請求關(guān)閉后,manager進(jìn)程會重新創(chuàng)建一個(gè)新的worker進(jìn)程礼殊,保證整個(gè)系統(tǒng)當(dāng)中worker進(jìn)程的數(shù)目是固定的驹吮。
參考網(wǎng)站: