Nginx的工作模式和一些理解

來源:互聯網
上載者:User
2、Nginx的工作模式以及可以處理高並發的一些理解

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

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

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.