Nginx 的進程模型
HTTP 連接建立和請求處理過程:
- Nginx 啟動時,Master 進程,加載配置文件
- Master 進程,初始化監(jiān)聽的 socket
- Master 進程,fork 出多個 Worker 進程
- Worker 進程,競爭新的連接,獲勝方通過三次握手,建立 Socket 連接,并處理請求
Nginx 高性能、高并發(fā):
- Nginx 采用:多進程 + 異步非阻塞方式(IO 多路復用 epoll)
- 請求的完整過程:
- 建立連接
- 讀取請求:解析請求
- 處理請求
- 響應請求
- 請求的完整過程,對應到底層,就是:讀寫 socket 事件
Nginx 的事件處理模型
request:Nginx 中 http 請求。
基本的 HTTP Web Server 工作模式:
- 接收請求:逐行讀取請求行和請求頭,判斷段有請求體后,讀取請求體
- 處理請求
- 返回響應:根據(jù)處理結果,生成相應的 HTTP 請求(響應行、響應頭、響應體)
Nginx 也是這個套路,整體流程一致。
nginx的模塊根據(jù)其功能基本上可以分為以下幾種類型:
- event module: 搭建了獨立于操作系統(tǒng)的事件處理機制的框架,及提供了各具體事件的處理。包括ngx_events_module, ngx_event_core_module和ngx_epoll_module等。nginx具體使用何種事件處理模塊,這依賴于具體的操作系統(tǒng)和編譯選項。
- phase handler: 此類型的模塊也被直接稱為handler模塊。主要負責處理客戶端請求并產(chǎn)生待響應內(nèi)容,比如ngx_http_static_module模塊,負責客戶端的靜態(tài)頁面請求處理并將對應的磁盤文件準備為響應內(nèi)容輸出。
- output filter: 也稱為filter模塊,主要是負責對輸出的內(nèi)容進行處理,可以對輸出進行修改。例如,可以實現(xiàn)對輸出的所有html頁面增加預定義的footbar一類的工作,或者對輸出的圖片的URL進行替換之類的工作。
- upstream: upstream模塊實現(xiàn)反向代理的功能,將真正的請求轉(zhuǎn)發(fā)到后端服務器上,并從后端服務器上讀取響應,發(fā)回客戶端。upstream模塊是一種特殊的handler,只不過響應內(nèi)容不是真正由自己產(chǎn)生的,而是從后端服務器上讀取的。
- load-balancer: 負載均衡模塊,實現(xiàn)特定的算法,在眾多的后端服務器中,選擇一個服務器出來作為某個請求的轉(zhuǎn)發(fā)服務器。
本文名稱:Nginx為什么高效?一文搞明白Nginx核心原理
文章鏈接:http://muchs.cn/news7/98907.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供用戶體驗、網(wǎng)頁設計公司、網(wǎng)站策劃、響應式網(wǎng)站、網(wǎng)站制作、網(wǎng)站收錄
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源:
創(chuàng)新互聯(lián)