Nginx 由內(nèi)核和模塊組成。
Nginx 本身做的工作實際很少,當它接到一個 HTTP 請求時, 它僅僅是通過查找配置文件將此次請求映射到一個 location block,而此 location 中所配 置的各個指令則會啟動不同的模塊去完成工作,因此模塊可以看做 Nginx 真正的勞動工作者。
通常一個 location 中的指令會涉及一個 handler 模塊和多個 filter 模塊(當然,多個 location 可以復用同一個模塊)。handler 模塊負責處理請求,完成響應內(nèi)容的生成,而 filter 模塊對響應內(nèi)容進行處理。 用戶根據(jù)自己的需要所開發(fā)的模塊都屬于第三方模塊。正是有了這么多模塊的支撐, Nginx 的功能才會如此強大。
Nginx 的模塊從結(jié)構(gòu)上分為核心模塊、基礎(chǔ)模塊和第三方模塊:
?
核心模塊:HTTP 模塊、EVENT 模塊和 MAIL 模塊; ?
基礎(chǔ)模塊:HTTP Access 模塊、HTTP FastCGI 模塊、HTTP Proxy 模塊和 HTTP Rewrite 模塊;
第三方模塊:HTTP Upstream Request Hash 模塊、Notice 模塊和 HTTP Access Key 模 塊。
?
Nginx 的模塊從功能上分為如下三類: ?
Handlers(處理器模塊):此類模塊直接處理請求,并進行輸出內(nèi)容和修改 headers 信息等操作。Handlers 處理器模塊一般只能有一個; ?Filters(過濾器模塊):此類模塊主要對其他處理器模塊輸出的內(nèi)容進行修改操作,最后由 Nginx 輸出; Proxies(代理類模塊):此類模塊是 Nginx 的 HTTP Upstream 之類的模塊,這些模塊主要與后端一些服務比如 FastCGI 等進行交互,實現(xiàn)服務代理和負載均衡等功能。
Nginx 的進程模型 在工作方式上,Nginx 分為單工作進程和多工作進程兩種模式。 ?
在單工作進程模式下,除主進程外,還有一個工作進程,工作進程是單線程的; ?
在多工作進程模式下,每個工作進程包含多個線程。Nginx 默認為單工作進程模式。
Nginx 在啟動后,會有一個 master 進程和多個 worker 進程。
master 進程主要用來管理 worker 進程,主要包含:接收來自外界的信號,向各 worker 進程發(fā)送信號,監(jiān)控 worker 進程的運行狀態(tài),當 worker 進程退出后(異常情況下),會自動 重新啟動新的 worker 進程。 master 進程充當整個進程組與用戶的交互接口,同時對進程進行監(jiān)護。它不需要處理網(wǎng)絡事件,不負責業(yè)務的執(zhí)行,只會通過管理worker 進程來實現(xiàn)重啟服務、平滑升級、更換日志文件、配置文件實時生效等功能。
3.Nginx FastCGI運行原理
Nginx 不支持對外部程序的直接調(diào)用或者解析,所有的外部程序(包括 PHP)必須通過FastCGI 接口來調(diào)用。FastCGI 接口在 Linux 下是 socket(這個 socket 可以是文件 socket, 也可以是 ip socket)。 wrapper 為了調(diào)用 CGI 程序,還需要一個 FastCGI 的 wrapper(wrapper 可以理解為用于啟動另一個程序的程序),這個 wrapper 綁定在某個固定 socket 上,如端口或者文件 socket。當 Nginx 將 CGI 請求發(fā)送給這個 socket 的時候,通過 FastCGI 接口,wrapper 接收到請求,然后 Fork(派生)出一個新的線程,這個線程調(diào)用解釋器或者外部程序處理腳本并讀取返回數(shù)據(jù);接著 wrapper 再將返回的數(shù)據(jù)通過 FastCGI 接口,沿著固定的 socket傳遞給 Nginx;最后 Nginx 將返回的數(shù)據(jù)(html 頁面或者圖片)發(fā)送給客戶端。
更多關(guān)于云服務器,域名注冊,虛擬主機的問題,請訪問西部數(shù)碼官網(wǎng):m.bingfeng168.cn