Nginx 多進程架構(gòu)和驚群問題

Nginx 多進程架構(gòu)是:一個master進程和多個worker 進程。
一個worker 通過非阻塞式論詢,可維護數(shù)千個連接,多個worker共享一個監(jiān)聽套接字.

Master進程

顧名思義,老板進程,主要負(fù)責(zé)有輕而巧的工作.
主要通過進程間通信對工人進程發(fā)號施令或是處理來自bash的start,stop,reload等用戶指令射亏。

Worker 進程

顧名思義,工人進程,主要負(fù)責(zé)重而笨的工作,主要負(fù)責(zé)處理來自瀏覽器的連接返弹。
網(wǎng)站高并發(fā)情況下锈玉,巨大的工作負(fù)荷都是壓到工人進程,老板進程在一旁觀看指揮义起。

在TCP Socket 服務(wù)開發(fā)中,多進程或多線程共享監(jiān)聽套接字時面臨驚群問題.

  1. 對于主流的linx版本, accept 阻塞調(diào)用,已經(jīng)不存在驚群問題.
    也就是說多個進程同時accept 同一個 監(jiān)聽套接字,只有一個進程獲的連接.

  2. 對于epoll_wait 非阻塞式的創(chuàng)建連接方式, 存在驚群問題拉背。(即:一個連接請求喚醒多個worker 進程).

Nginx 在linux系統(tǒng)中使用epoll_wait 非阻塞式的方式,存在驚群問題默终。

瀏覽器的請求連接不經(jīng)過master進程椅棺,直接由worker 進程處理,
但是一個請求如何分配到特定的worker進程?

  1. nginx 默認(rèn)的配置accept_mutex on;
    多個worker 進程通過爭鎖獲得連接齐蔽,同時只有一個worker獲得連接两疚。
    工人進程搶著活干(讓我來,別和我爭)
  2. accept_mutex off
    一個連接請求喚醒多個worker 進程含滴,同時只有一個worker獲得連接诱渤。
    存在驚群問題,由于nginx 的worker 進程數(shù)量不大蛙吏,這個驚群問題影響不大源哩。
    少了爭鎖,這個配置高并發(fā)時可提高系統(tǒng)的響應(yīng)能力鸦做。
  3. 開啟SO_REUSEPORT選項: reuseport
http {
        server {
          listen 80 reuseport;
          server_name  localhost;
          ...
     }
}

SO_REUSEPORT選項,是Linux 內(nèi)核3.9+處理大并發(fā)連接的新特性励烦。
開啟后,連接請求通過linux內(nèi)核分配到worker 進程泼诱,性能最好坛掠。
此選項的系統(tǒng)需求:
Nginx 1.9.1+
DragonFly BSD/Linux 內(nèi)核3.9+

參考:
http://blog.csdn.net/Marcky/
https://www.nginx.com/blog/socket-sharding-nginx-release-1-9-1/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市治筒,隨后出現(xiàn)的幾起案子屉栓,更是在濱河造成了極大的恐慌,老刑警劉巖耸袜,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件友多,死亡現(xiàn)場離奇詭異,居然都是意外死亡堤框,警方通過查閱死者的電腦和手機域滥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蜈抓,“玉大人启绰,你說我怎么就攤上這事」凳梗” “怎么了委可?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長腊嗡。 經(jīng)常有香客問我着倾,道長拾酝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任屈呕,我火速辦了婚禮微宝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘虎眨。我一直安慰自己蟋软,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布嗽桩。 她就那樣靜靜地躺著岳守,像睡著了一般。 火紅的嫁衣襯著肌膚如雪碌冶。 梳的紋絲不亂的頭發(fā)上湿痢,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天,我揣著相機與錄音扑庞,去河邊找鬼譬重。 笑死,一個胖子當(dāng)著我的面吹牛罐氨,可吹牛的內(nèi)容都是我干的臀规。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼栅隐,長吁一口氣:“原來是場噩夢啊……” “哼塔嬉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起租悄,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤谨究,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后泣棋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體胶哲,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年潭辈,在試婚紗的時候發(fā)現(xiàn)自己被綠了纪吮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡萎胰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出棚辽,到底是詐尸還是另有隱情技竟,我是刑警寧澤,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布屈藐,位于F島的核電站榔组,受9級特大地震影響熙尉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜搓扯,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一检痰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锨推,春花似錦铅歼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至沾鳄,卻和暖如春慨飘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背译荞。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工瓤的, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吞歼。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓圈膏,卻偏偏與公主長得像,于是被迫代替她去往敵國和親浆熔。 傳聞我的和親對象是個殘疾皇子本辐,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,781評論 2 354

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

  • 什么是Nginx? Nginx是一個高性能的HTTP和反向代理服務(wù)器医增,也是一個IMAP/POP3/SMTP服務(wù)器N...
    jiangmo閱讀 2,540評論 1 9
  • 1. Nginx的模塊與工作原理 Nginx由內(nèi)核和模塊組成慎皱,其中,內(nèi)核的設(shè)計非常微小和簡潔叶骨,完成的工作也非常簡單...
    rosekissyou閱讀 10,214評論 5 124
  • 第一章 Nginx簡介 Nginx是什么 沒有聽過Nginx茫多?那么一定聽過它的“同行”Apache吧!Ngi...
    JokerW閱讀 32,672評論 24 1,002
  • 上一篇《WEB請求處理一:瀏覽器請求發(fā)起處理》忽刽,我們講述了瀏覽器端請求發(fā)起過程天揖,通過DNS域名解析服務(wù)器IP,并建...
    七寸知架構(gòu)閱讀 81,002評論 21 356
  • 夜皇雪閱讀 222評論 0 0