首頁 >後端開發 >php教程 >Nginx的工作模式和一些理解

Nginx的工作模式和一些理解

WBOY
WBOY原創
2016-07-29 08:50:571103瀏覽

2、Nginx的工作模式以及可以處理高同時的一些理解 

 Nginx的工作模式很簡單,就是採用一個master進程和多個worker工作進程,其中master進程的作用也是很明確的就是負責管理worker進程,同時監聽連線請求,當連線請求到來之後將連線放入worker進程中去處理具體的業務請求,比如說http請求。 Nginx能夠處理高並發的原因在於對socket的管理方式是異步非阻塞的,使用select/poll/epoll/kqueue 來實現對大量socket描述符的管理,每個worker進程有一個主線程,而沒有其他的線程這樣的好處就在於不需要進行線程間的切換,這樣就節省了資源。所以總的來說:Nginx能夠實現支援高並發的同時運行效率還很低的關鍵在於整個系統內部只有有限的幾個工作進程和一個監聽進程,而每個進程內部只有一個主線程,這樣就不會引起很多的線程切換,從而降低了系統開銷,同時每個線程內部使用異步非阻塞的方式來管理描述符這樣就可以管理大量的描述符,當描述符多的時候也只是會佔用較多的內存而已,而不會造成佔用大量cpu時間。以上說的就是Nginx的進程模型和事件模型,事件模型中處理的情況主要有三種,分別是網路事件,如HTTP請求等,網路事件使用非同步非阻塞模式就可以很好的解決;還有訊號,定時器,訊號和定時器還不是很明白。 Nginx處理進程間爭奪系統資源的方式:也就是進程間存在的驚群現象。

以上就介紹了Nginx的工作模式和一些理解,包括了方面的內容,希望對PHP教程有興趣的朋友有幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn