nginx有幾種工作模式
1 回答

慕的地10843
TA貢獻1785條經驗 獲得超8個贊
Nginx的工作模式很簡單,就是采用一個master進程和多個worker工作進程,其中master進程的作用也是很明確的就是負責管理worker進程,同時監聽連接請求,當連接請求到來之后將連接放入worker進程中去處理具體的業務請求,比如說http請求。 Nginx能夠處理高并發的原因在于對socket的管理方式是異步非阻塞的,使用select/poll/epoll/kqueue 來實現對大量socket描述符的管理,每個worker進程有一個主線程,而沒有其他的線程這樣的好處就在于不需要進行線程間的切換,這樣就節省了資源。所以總的來說:Nginx能夠實現支持高并發的同時運行效率還很低的關鍵在于整個系統內部只有有限的幾個工作進程和一個監聽進程,而每個進程內部只有一個主線程,這樣就不會引起很多的線程切換,從而降低了系統開銷,同時每個線程內部使用異步非阻塞的方式來管理描述符這樣就可以管理大量的描述符,當描述符多的時候也只是會占用較多的內存而已,而不會造成占用大量cpu時間。以上說的就是Nginx的進程模型和事件模型,事件模型中處理的情況主要有三種,分別是網絡事件,如HTTP請求等,網絡事件使用異步非阻塞模式就可以很好的解決;還有信號,定時器,信號和定時器還不是很明白。Nginx處理進程間爭奪系統資源的方式:也就是進程間存在的驚群現象。
- 1 回答
- 0 關注
- 2386 瀏覽
添加回答
舉報
0/150
提交
取消