Swoole 進(jìn)程相關(guān)知識

進(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)程。如下圖所示:

\1.PNG
\1.PNG

需要注意的是:

  • 子進(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)缝裁,如下圖所示:

\2.PNG
\2.PNG

整個(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)站:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市晶伦,隨后出現(xiàn)的幾起案子碟狞,更是在濱河造成了極大的恐慌,老刑警劉巖婚陪,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件族沃,死亡現(xiàn)場離奇詭異,居然都是意外死亡泌参,警方通過查閱死者的電腦和手機(jī)脆淹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沽一,“玉大人盖溺,你說我怎么就攤上這事∠巢” “怎么了烘嘱?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蝗蛙。 經(jīng)常有香客問我蝇庭,道長,這世上最難降的妖魔是什么捡硅? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任哮内,我火速辦了婚禮,結(jié)果婚禮上壮韭,老公的妹妹穿的比我還像新娘北发。我一直安慰自己纹因,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布鲫竞。 她就那樣靜靜地躺著辐怕,像睡著了一般逼蒙。 火紅的嫁衣襯著肌膚如雪从绘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天是牢,我揣著相機(jī)與錄音僵井,去河邊找鬼。 笑死驳棱,一個(gè)胖子當(dāng)著我的面吹牛批什,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播社搅,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼驻债,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了形葬?” 一聲冷哼從身側(cè)響起合呐,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎笙以,沒想到半個(gè)月后淌实,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡猖腕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年拆祈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片倘感。...
    茶點(diǎn)故事閱讀 38,622評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡放坏,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出老玛,到底是詐尸還是另有隱情淤年,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布逻炊,位于F島的核電站互亮,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏余素。R本人自食惡果不足惜豹休,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望桨吊。 院中可真熱鬧威根,春花似錦凤巨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至留美,卻和暖如春彰檬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谎砾。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工逢倍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人景图。 一個(gè)月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓较雕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親挚币。 傳聞我的和親對象是個(gè)殘疾皇子亮蒋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內(nèi)容