午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 詳解nginx驚群問題的解決方式

詳解nginx驚群問題的解決方式

熱門標簽:淘寶辦理400電話是多少 外呼線路隨意切換嗎 滴滴急救中心地圖標注 申請400電話收費標 網絡電話外呼系統開發 艾澤拉斯地圖標注 福州語音電銷機器人招商 北海智能電銷機器人公司 菏澤自動電銷機器人公司

對于nginx的驚群問題,我們首先需要理解的是,在nginx啟動過程中,master進程會監聽配置文件中指定的各個端口,然后master進程就會調用fork()方法創建各個子進程,根據進程的工作原理,子進程是會繼承父進程的全部內存數據以及監聽的端口的,也就是說worker進程在啟動之后也是會監聽各個端口的。關于驚群,指的就是當客戶端有新建連接的請求到來時,就會觸發各個worker進程的連接建立事件,但是只有一個worker進程能夠正常處理該事件,而其他的worker進程會發現事件已經失效,從而重新循環進入等待狀態。這種由于一個事件而“驚”起了所有worker進程的現象就是驚群問題。很明顯,如果所有的worker進程都被觸發了,那么這將消耗大量的資源,本文則主要講解nginx是如何處理驚群問題的。

1. 解決方式

在前面的文章中,我們講到,每個worker進程被創建的時候,都會調用ngx_worker_process_init()方法初始化當前worker進程,這個過程中有一個非常重要的步驟,即每個worker進程都會調用epoll_create()方法為自己創建一個獨有的epoll句柄。對于每一個需要監聽的端口,都有一個文件描述符與之對應,而worker進程只有將該文件描述符通過epoll_ctl()方法添加到當前進程的epoll句柄中,并且監聽accept事件,此時才會被客戶端的連接建立事件觸發,從而處理該事件。從這里也可以看出,worker進程如果沒有將所需要監聽的端口對應的文件描述符添加到該進程的epoll句柄中,那么其是無法被觸發對應的事件的。基于這個原理,nginx就使用了一個共享鎖來控制當前進程是否有權限將需要監聽的端口添加到當前進程的epoll句柄中,也就是說,只有獲取鎖的進程才會監聽目標端口。通過這種方式,就保證了每次事件發生時,只有一個worker進程會被觸發。如下圖所示為worker進程工作循環的一個示意圖:

這里關于圖中的流程,需要說明的一點是,每個worker進程在進入循環之后就會嘗試獲取共享鎖,如果沒有獲取到,就會將所監聽的端口的文件描述符從當前進程的epoll句柄中移除(即使并不存在也會移除),這么做的主要目的是防止丟失客戶端連接事件,即使這可能造成少量的驚群問題,但是并不嚴重。試想一下,如果按照理論,在當前進程釋放鎖的時候就將監聽的端口的文件描述符從epoll句柄中移除,那么在下一個worker進程獲取鎖之前,這段時間各個端口對應的文件描述符是沒有任何epoll句柄進行監聽的,此時就會造成事件的丟失。如果反過來,按照圖中的在獲取鎖失敗的時候才移除監聽的文件描述符,由于獲取鎖失敗,則說明當前一定有一個進程已經監聽了這些文件描述符,因而此時移除是安全的。但是這樣會造成的一個問題是,按照上圖,當前進程在一個循環執行完畢的時候,會釋放鎖,然后處理其他的事件,注意這個過程中其是沒有釋放所監聽的文件描述符的。此時,如果另一個進程獲取到了鎖,并且監聽了文件描述符,那么這個時候就有兩個進程監聽了文件描述符,因而此時如果客戶端發生連接建立事件,那么就會觸發兩個worker進程。這個問題是可以容忍的,主要原因有兩點:

  1. 這個時候發生的驚群現象只觸發了更少的worker進程,比起每次都驚起所有的worker進程要好很多;
  2. 會發生這種驚群問題的主要原因是,當前進程釋放了鎖,但是沒有釋放所監聽的文件描述符,但是worker進程在釋放鎖之后主要是處理客戶端連接的讀寫事件和檢查標志位,這個過程是非常短的,在處理完之后,其就會嘗試獲取鎖,這個時候就會釋放所監聽的文件描述符了,而相較而言,獲取鎖的worker進程在等待處理客戶端的連接建立事件的事件就更長了,因而會發生驚群問題的概率還是比較小的。

2. 源碼講解

worker進程初始事件的方法主要是在ngx_process_events_and_timers()方法中進行的,下面我們就來看看該方法是如何處理整個流程的,如下是該方法的源碼:

void ngx_process_events_and_timers(ngx_cycle_t *cycle) {
 ngx_uint_t flags;
 ngx_msec_t timer, delta;

 if (ngx_trylock_accept_mutex(cycle) == NGX_ERROR) {
  return;
 }

 // 這里開始處理事件,對于kqueue模型,其指向的是ngx_kqueue_process_events()方法,
 // 而對于epoll模型,其指向的是ngx_epoll_process_events()方法
 // 這個方法的主要作用是,在對應的事件模型中獲取事件列表,然后將事件添加到ngx_posted_accept_events
 // 隊列或者ngx_posted_events隊列中
 (void) ngx_process_events(cycle, timer, flags);

 // 這里開始處理accept事件,將其交由ngx_event_accept.c的ngx_event_accept()方法處理;
 ngx_event_process_posted(cycle, &ngx_posted_accept_events);

 // 開始釋放鎖
 if (ngx_accept_mutex_held) {
  ngx_shmtx_unlock(&ngx_accept_mutex);
 }

 // 如果不需要在事件隊列中進行處理,則直接處理該事件
 // 對于事件的處理,如果是accept事件,則將其交由ngx_event_accept.c的ngx_event_accept()方法處理;
 // 如果是讀事件,則將其交由ngx_http_request.c的ngx_http_wait_request_handler()方法處理;
 // 對于處理完成的事件,最后會交由ngx_http_request.c的ngx_http_keepalive_handler()方法處理。

 // 這里開始處理除accept事件外的其他事件
 ngx_event_process_posted(cycle, &ngx_posted_events);
}

上面的代碼中,我們省略了大部分的檢查工作,只留下了骨架代碼。首先,worker進程會調用ngx_trylock_accept_mutex()方法獲取鎖,這其中如果獲取到了鎖就會監聽各個端口對應的文件描述符。然后會調用ngx_process_events()方法處理epoll句柄中監聽到的事件。接著會釋放共享鎖,最后就是處理已建立連接的客戶端的讀寫事件。下面我們來看一下ngx_trylock_accept_mutex()方法是如何獲取共享鎖的:

ngx_int_t ngx_trylock_accept_mutex(ngx_cycle_t *cycle) {
 // 嘗試使用CAS算法獲取共享鎖
 if (ngx_shmtx_trylock(&ngx_accept_mutex)) {

  // ngx_accept_mutex_held為1表示當前進程已經獲取到了鎖
  if (ngx_accept_mutex_held && ngx_accept_events == 0) {
   return NGX_OK;
  }

  // 這里主要是將當前連接的文件描述符注冊到對應事件的隊列中,比如kqueue模型的change_list數組
  // nginx在啟用各個worker進程的時候,默認情況下,worker進程是會繼承master進程所監聽的socket句柄的,
  // 這就導致一個問題,就是當某個端口有客戶端事件時,就會把監聽該端口的進程都給喚醒,
  // 但是只有一個worker進程能夠成功處理該事件,而其他的進程被喚醒之后發現事件已經過期,
  // 因而會繼續進入等待狀態,這種現象稱為"驚群"現象。
  // nginx解決驚群現象的方式一方面是通過這里的共享鎖的方式,即只有獲取到鎖的worker進程才能處理
  // 客戶端事件,但實際上,worker進程是通過在獲取鎖的過程中,為當前worker進程重新添加各個端口的監聽事件,
  // 而其他worker進程則不會監聽。也就是說同一時間只有一個worker進程會監聽各個端口,
  // 這樣就避免了"驚群"問題。
  // 這里的ngx_enable_accept_events()方法就是為當前進程重新添加各個端口的監聽事件的。
  if (ngx_enable_accept_events(cycle) == NGX_ERROR) {
   ngx_shmtx_unlock(&ngx_accept_mutex);
   return NGX_ERROR;
  }

  // 標志當前已經成功獲取到了鎖
  ngx_accept_events = 0;
  ngx_accept_mutex_held = 1;

  return NGX_OK;
 }

 // 前面獲取鎖失敗了,因而這里需要重置ngx_accept_mutex_held的狀態,并且將當前連接的事件給清除掉
 if (ngx_accept_mutex_held) {
  // 如果當前進程的ngx_accept_mutex_held為1,則將其重置為0,并且將當前進程在各個端口上的監聽
  // 事件給刪除掉
  if (ngx_disable_accept_events(cycle, 0) == NGX_ERROR) {
   return NGX_ERROR;
  }

  ngx_accept_mutex_held = 0;
 }

 return NGX_OK;
}

上面的代碼中,本質上主要做了三件事:

  1. 通過ngx_shmtx_trylock()方法嘗試使用CAS方法獲取共享鎖;
  2. 獲取鎖之后則調用ngx_enable_accept_events()方法監聽目標端口對應的文件描述符;
  3. 如果沒有獲取到鎖,則調用ngx_disable_accept_events()方法釋放所監聽的文件描述符;

3. 小結

本文首先對驚群現象的產生原因進行了講解,然后介紹了nginx是如何解決驚群問題的,最后從源碼角度對nginx處理驚群問題的方式進行了講解。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:滄州 延安 三沙 混顯 亳州 資陽 丹東 賀州

巨人網絡通訊聲明:本文標題《詳解nginx驚群問題的解決方式》,本文關鍵詞  詳解,nginx,驚群,問,題的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解nginx驚群問題的解決方式》相關的同類信息!
  • 本頁收集關于詳解nginx驚群問題的解決方式的相關信息資訊供網民參考!
  • 推薦文章
    国产美女直播视频一区| 欧美性受xxxx黑人| 婷婷综合五月天| 日韩av片在线| 国产成人精品一区二区| 久久国产人妖系列| 路边理发店露脸熟妇泻火| 欧美精品电影在线播放| 一区二区视频网站| 好吊色欧美一区二区三区视频| 久久久久久久精| 成人免费视频久久| 一区二区三区**美女毛片| 久久精品这里有| 欧美美乳视频网站在线观看| 日本一区视频在线观看| 久久亚洲欧美国产精品乐播| 草草影院第一页| 国产欧美日韩综合精品| 亚洲美女搞黄| 国产精品传媒在线| 丁香花五月婷婷| 国产精品初高中精品久久| 欧美色男人天堂| 国产精品久久久久久久一区二区| 国产精品网站免费| 日韩中文字幕欧美| 国产精品18久久久久| 国产精品99久久久久久成人| 亚洲va码欧洲m码| 91精品国产入口| 在线看的片片片免费| 国产欧美韩日| 国产亚洲综合久久| 九色porny丨国产精品| 国产不卡在线观看视频| 国产日韩第一页| 高清欧美性猛交xxxx黑人猛交| 26uuu色噜噜精品一区二区| 日韩伦理在线视频| 日韩在线第三页| 欧美资源在线观看| 亚洲v中文字幕| 麻豆成人久久精品二区三区红 | 国产男女猛烈无遮挡91| 91麻豆精品久久久久蜜臀| 日韩中文字幕免费在线观看| 国产免费看av| 免费电影一区| 国产精品91久久| 在线播放日韩导航| 中文字幕不卡在线观看| 五月婷婷激情视频| 国产精品成人av性教育| 亚洲第一区在线观看| 一区二区三区视频在线观看| 久草在线在线精品观看| 久久久久在线视频| 国产在线免费av| 不卡中文字幕在线观看| 国产精品免费在线| 久久免费精品视频| 亚洲国产成人爱av在线播放| 白白色亚洲国产精品| 性猛交娇小69hd| 久久99久久99精品| 亚洲国产一区二区三区在线| 亚洲欧美国产不卡| 深田咏美在线x99av| 中文字幕66页| 国产91xxx| 91精品视频免费观看| 亚洲人成电影网站色xx| 亚洲成人激情图| 国产综合色精品一区二区三区| 国产在线免费看| 成人在线观看www| 欧美亚洲国产视频| 欧美男男青年gay1069videost| 蜜臀国产一区二区三区在线播放| 最近中文字幕免费观看| 亚洲av成人片色在线观看高潮 | 国产成人精品一区二 | 日本亚洲一区二区三区| 欧美激情国产精品日韩| 男女视频网站在线观看| 51久久精品夜色国产麻豆| 精品国产乱子伦一区| 欧美网站在线观看| 亚洲精选视频免费看| 欧美激情一区二区三区在线| 日批视频免费播放| 日批视频免费观看| 激情综合激情五月| 男人网站在线观看| 丁香五月网久久综合| 日韩亚洲欧美中文高清在线| 精品国产亚洲一区二区三区在线观看| 亚洲精品日韩综合观看成人91| 成人美女视频在线看| 国产又黄又大久久| 九九热在线视频观看这里只有精品| 手机看片1024国产| 天堂国产一区二区三区| 国产v在线观看| 国产高清第一页| 精品久久人妻av中文字幕| 国产精品自偷自拍| www.色亚洲| 免费a级片在线观看| 性一交一乱一乱一视频| 国产日韩免费视频| 成 人片 黄 色 大 片| 精品黑人一区二区三区国语馆| а√中文在线资源库| 蜜臀va亚洲va欧美va天堂| 国产美女av一区二区三区| 成人午夜在线播放| 久久精品亚洲麻豆av一区二区 | 中文字幕日韩综合av| 欧美一区二区久久| 欧洲精品一区二区| 精品国产乱码久久久久久夜甘婷婷| 激情av一区二区| 欧美福利一区二区| www.日韩视频| 亚洲va电影大全| 久久伊人精品视频| 另类少妇人与禽zozz0性伦| 亚洲第一区在线观看| 日韩av在线免播放器| 在线观看一区日韩| 亚洲国产欧美日韩精品| 中文字幕不卡av| 91精品国产亚洲| 久久99导航| 欧美深夜福利视频| 欧美一级黄色影院| 91久久免费视频| 国产91国语对白在线| 成人小视频在线播放| 中文字幕乱码一区二区| 韩国欧美国产一区| 国产婷婷一区二区| 亚洲精品美国一| 欧美精品一区二区久久婷婷| 欧美日韩aaaa| 成人动漫在线观看视频| 免费成人午夜视频| zjzjzjzjzj亚洲女人| 综合 欧美 亚洲日本| 日本熟妇乱子伦xxxx| av资源免费看| 精久久久久久久久久久| 一区二区三区资源| 精品嫩草影院久久| 精品国偷自产在线视频99| 51国偷自产一区二区三区| 妞干网在线观看视频| 国产麻豆a毛片| 手机看片国产1024| 91亚洲大成网污www| 91麻豆精品国产91久久久久久| 美女福利视频一区| 婷婷精品国产一区二区三区日韩| 日本www在线视频| 激情高潮到大叫狂喷水| 国产又粗又猛又爽又黄的视频一| 国产乱人伦偷精品视频免下载| 色综合一个色综合亚洲| 久久久久久久久久久免费精品| 成人资源av| 国产麻豆剧传媒精品国产av| 综合网在线观看| 久久久青草青青国产亚洲免观| 亚洲成人黄色网址| 国产乱码精品一区二区三区卡| 欧美精品自拍视频| 久久久视频6r| 精品一区二区三区不卡| 欧美日韩亚洲精品一区二区三区| 亚洲精品综合久久中文字幕| 久久精品国产一区二区三区不卡| 人妻av一区二区| 亚洲产国偷v产偷v自拍涩爱| ●精品国产综合乱码久久久久| 色婷婷**av毛片一区| 成年丰满熟妇午夜免费视频| 日韩欧美国产成人精品免费| 老熟妇高潮一区二区高清视频| 日本一区二区高清| 亚洲毛片在线观看| 免费的av在线| 99久久99久久精品国产| 久久超碰97中文字幕| 在线播放91灌醉迷j高跟美女| 国产精品视频500部| 无码国产69精品久久久久网站| 亚洲三级黄色片| 欧美一三区三区四区免费在线看| 国产亚洲情侣一区二区无| 精品熟妇无码av免费久久| 国产综合无码一区二区色蜜蜜| 国产精品久久影院| 最近2019中文字幕一页二页| 日本三日本三级少妇三级66| 国产原创视频在线| 18成人在线观看| 韩国v欧美v日本v亚洲| 一级淫片在线观看| 国产手机视频在线| 欧美精品免费视频| 色阁综合av| 国产av无码专区亚洲av毛网站| 国产精品污网站| 91精品国产乱码久久久久久蜜臀| 在线看免费毛片| 国产91精品欧美| 久久99久久久久久久噜噜| 欧美一二三区| 亚洲图色中文字幕| 国产一区二区三区在线观看精品 | 久久国产柳州莫菁门| 91麻豆国产精品久久| 国产美女久久久| 国产成人无码一区二区三区在线| 亚洲色图视频免费播放| 国产原创精品| 中文字幕在线网站| jizz18女人| 免费91在线观看| 亚洲成人激情综合网| 精品国产乱码久久久久| 欧美日韩中文字幕在线观看| 色婷婷精品大视频在线蜜桃视频| 午夜精品区一区二区三| 一区二区三区四区五区视频在线观看| 欧美精品一区二区久久婷婷| 黄黄视频在线观看| 亚洲人妻一区二区三区| av无码一区二区三区| 在线观看xxx| 久久免费视频网站| 中国丰满人妻videoshd| 国产一区精品视频| 久久久久亚洲av无码网站| 国产综合久久久久久鬼色| 97国产一区二区精品久久呦| 欧美曰成人黄网| 欧美高清性猛交| 欧美另类videoxo高潮| 欧美激情中文不卡| 国产经典一区二区三区| 国产又大又粗又硬| 日韩精品视频免费专区在线播放| 亚洲一二三不卡| 岛国精品在线播放| 伊人久久五月天| 色欲狠狠躁天天躁无码中文字幕| 五月天视频一区| 国产乱人伦精品一区二区三区| 久久亚洲风情| 色偷偷偷亚洲综合网另类| 欧美色视频一区二区三区在线观看| 欧美tk—视频vk| 国产高清999| 五月综合激情日本mⅴ| 天天爱天天操天天干| 97精品久久久久中文字幕| 国产日韩欧美在线看| 欧美男人亚洲天堂| 这里精品视频免费| 日本熟女一区二区| 亚洲欧美日韩天堂一区二区| 性猛交╳xxx乱大交| 亚洲免费观看视频| www.好吊操| 日本一二三不卡| 亚洲精品天堂成人片av在线播放 | 国产精品久久久久国产a级| 欧美日韩国产精品综合| 亚洲视频日韩精品| 国产精品免费人成网站酒店| 亚洲男人天堂视频| 久久久久久久久久影院| 精品国产一区二区三区久久狼黑人| 亚洲另类欧美日韩| 久久九九国产精品怡红院| 国产亚洲色婷婷久久99精品91| 色狠狠综合天天综合综合| 超碰在线公开97| 欧洲精品在线观看| 永久免费av无码网站性色av| 中文精品99久久国产香蕉| 一二三区免费视频| 欧美做受高潮电影o| 天堂中文在线观看视频| 国产精品网站入口| 人妻夜夜爽天天爽| 亚洲精品欧美极品| aaa国产一区| 日韩福利视频| 亚洲成人一区二区| www.黄色在线| 海角国产乱辈乱精品视频| 国产精品久久久久久久免费| 日本精品免费观看| 国产又黄又大久久| 天天做天天爱天天高潮| 亚洲成人自拍网| 日本aaa视频| 久久成人国产精品| 92久久精品一区二区| 国产日产欧美a一级在线| 波多野结衣中文字幕一区二区三区| 欧美在线观看黄| 欧美精品在线一区二区三区| 欧美日韩偷拍视频| 韩日欧美一区二区| 国产黄色av网站| 亚洲精蜜桃久在线| 在线观看亚洲专区| 无码日韩精品一区二区| 国产精品男女猛烈高潮激情| 蜜桃久久精品一区二区| 一本久道久久综合狠狠爱亚洲精品| 性感美女极品91精品| 国产第一页浮力| 欧美性视频精品| 国产一区二区视频在线| 国产一伦一伦一伦| 久久99视频免费| 免费观看30秒视频久久| 亚洲欧洲日本精品| 亚洲精品福利免费在线观看| 国产精品久久影视| 99re在线播放| 亚洲精品一二三| 久久国产在线观看| 亚洲a级在线观看| 黑人巨大精品欧美一区二区| 欧美黄片一区二区三区| 国产高清在线一区| 91官网在线观看| 全部毛片永久免费看| 国产精品久久久久久久久久直播| 欧美日韩一区二区三区 | 精品无码久久久久久久| 精品日韩电影| 91精品国产综合久久久久久漫画 | 国产精品高清在线观看| 久久久www成人免费无遮挡大片 | 久久久久亚洲av片无码| 亚洲综合精品一区二区| 欧美日韩专区在线| 免费又黄又爽又猛大片午夜| 视频一区二区三区在线观看| 亚洲国产精品yw在线观看 | 天天插天天射天天干| 国产精品一区二区久久| 图片区日韩欧美亚洲| 无码人妻丰满熟妇区bbbbxxxx | 极品美妇后花庭翘臀娇吟小说| 国产免费成人av| 欧美性三三影院| 亚洲精品18p| 中文字幕在线观看91| 国产精品嫩草视频| 91成人网在线| 欧美特级特黄aaaaaa在线看| 日本高清一区二区视频| 亚洲一区久久久| 精品国产伦理网| 99这里只有久久精品视频| 91视频免费在观看| 日韩jizzz| 在线中文字幕日韩| 国产片一区二区| 成人毛片在线播放| 佐山爱在线视频| 国产美女高潮久久白浆| 亚洲国产精品999| 久久婷婷综合激情| 特一级黄色大片| 三年中国国语在线播放免费| 久久视频在线视频| 午夜精品久久久久久久久| 精品中文字幕一区二区| 欧美精品入口蜜桃| 欧美日韩成人免费视频| 亚洲free性xxxx护士白浆| 日韩视频一区二区三区| 久久九九久精品国产免费直播| 国产91精品看黄网站在线观看| 37pao成人国产永久免费视频| 国产精品久久久久久久久久ktv| 精品国产乱码久久久久久浪潮 | 五十路熟女丰满大屁股| 久久综合一区二区三区| 91tv亚洲精品香蕉国产一区7ujn| 精品国产乱码久久久久久免费| 亚洲另类在线视频| 国产一区二区不卡在线| 中文字幕 自拍偷拍| 成人影视免费观看| 在线不卡一区二区三区| 精品一区二区三区国产| 亚洲一级免费视频| 欧美一区二区视频免费观看| av高清不卡在线|