nginx 的請求處理、請求的處理流程

nginx的請求處理

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。

nginx使用一個多進程模型來對外提供服務,其中一個master進程,多個worker進程。master進程負責管理nginx本身和其他worker進程。

所有實際上的業務處理邏輯都在worker進程。worker進程中有一個函數,執行無限循環,不斷處理收到的來自客戶端的請求,并進行處理,直到整個nginx服務被停止。

worker進程中,ngx_worker_process_cycle()函數就是這個無限循環的處理函數。在這個函數中,一個請求的簡單處理流程如下:

  1. 操作系統提供的機制(例如epoll, kqueue等)產生相關的事件。
  2. 接收和處理這些事件,如是接受到數據,則產生更高層的request對象。
  3. 處理request的header和body。
  4. 產生響應,并發送回客戶端。
  5. 完成request的處理。
  6. 重新初始化定時器及其他事件。

請求的處理流程

為了讓大家更好的了解nginx中請求處理過程,我們以HTTP Request為例,來做一下詳細地說明。

從nginx的內部來看,一個HTTP Request的處理過程涉及到以下幾個階段。

  1. 初始化HTTP Request(讀取來自客戶端的數據,生成HTTP Request對象,該對象含有該請求所有的信息)。
  2. 處理請求頭。
  3. 處理請求體。
  4. 如果有的話,調用與此請求(URL或者Location)關聯的handler。
  5. 依次調用各phase handler進行處理。

在這里,我們需要了解一下phase handler這個概念。phase字面的意思,就是階段。所以phase handlers也就好理解了,就是包含若干個處理階段的一些handler。

在每一個階段,包含有若干個handler,再處理到某個階段的時候,依次調用該階段的handler對HTTP Request進行處理。

通常情況下,一個phase handler對這個request進行處理,并產生一些輸出。通常phase handler是與定義在配置文件中的某個location相關聯的。

一個phase handler通常執行以下幾項任務:

  1. 獲取location配置。
  2. 產生適當的響應。
  3. 發送response header。
  4. 發送response body。

當nginx讀取到一個HTTP Request的header的時候,nginx首先查找與這個請求關聯的虛擬主機的配置。如果找到了這個虛擬主機的配置,那么通常情況下,這個HTTP Request將會經過以下幾個階段的處理(phase handlers):

NGX_HTTP_POST_READ_PHASE:
?讀取請求內容階段
NGX_HTTP_SERVER_REWRITE_PHASE:
?Server請求地址重寫階段
NGX_HTTP_FIND_CONFIG_PHASE:
?配置查找階段:
NGX_HTTP_REWRITE_PHASE:
?Location請求地址重寫階段
NGX_HTTP_POST_REWRITE_PHASE:
?請求地址重寫提交階段
NGX_HTTP_PREACCESS_PHASE:
?訪問權限檢查準備階段
NGX_HTTP_ACCESS_PHASE:
?訪問權限檢查階段
NGX_HTTP_POST_ACCESS_PHASE:
?訪問權限檢查提交階段
NGX_HTTP_TRY_FILES_PHASE:
?配置項try_files處理階段
NGX_HTTP_CONTENT_PHASE:
?內容產生階段
NGX_HTTP_LOG_PHASE:
?日志模塊處理階段

在內容產生階段,為了給一個request產生正確的響應,nginx必須把這個request交給一個合適的content handler去處理。如果這個request對應的location在配置文件中被明確指定了一個content handler,那么nginx就可以通過對location的匹配,直接找到這個對應的handler,并把這個request交給這個content handler去處理。這樣的配置指令包括像,perl,flv,proxy_pass,mp4等。

如果一個request對應的location并沒有直接有配置的content handler,那么nginx依次嘗試:

  1. 如果一個location里面有配置 random_index on,那么隨機選擇一個文件,發送給客戶端。
  2. 如果一個location里面有配置 index指令,那么發送index指令指明的文件,給客戶端。
  3. 如果一個location里面有配置 autoindex on,那么就發送請求地址對應的服務端路徑下的文件列表給客戶端。
  4. 如果這個request對應的location上有設置gzip_static on,那么就查找是否有對應的.gz文件存在,有的話,就發送這個給客戶端(客戶端支持gzip的情況下)。
  5. 請求的URI如果對應一個靜態文件,static module就發送靜態文件的內容到客戶端。

內容產生階段完成以后,生成的輸出會被傳遞到filter模塊去進行處理。filter模塊也是與location相關的。所有的fiter模塊都被組織成一條鏈。輸出會依次穿越所有的filter,直到有一個filter模塊的返回值表明已經處理完成。

這里列舉幾個常見的filter模塊,例如:

  1. server-side includes。
  2. XSLT filtering。
  3. 圖像縮放之類的。
  4. gzip壓縮。

在所有的filter中,有幾個filter模塊需要關注一下。按照調用的順序依次說明如下:

write:寫輸出到客戶端,實際上是寫到連接對應的socket上。
postpone:這個filter是負責subrequest的,也就是子請求的。
copy:將一些需要復制的buf(文件或者內存)重新復制一份然后交給剩余的body filter處理。

轉自:http://tengine.taobao.org/book/chapter_02.html#id13?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/448216.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448216.shtml
英文地址,請注明出處:http://en.pswp.cn/news/448216.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何控制油門更準確?

學員問:平時練車還不錯,可是一換車就容易加大油門,有什么方法能很好的控制油呢?? 如何控制油門更準確?和調的座位有關系嗎?? 答:油門跟剎車被視為汽車控制的靈魂。汽車發…

使用線程——創建線程

CreateThread函數創建一個進程的新的線程。創建線程必須指定新線程要執行的代碼的起始地址。通常,起始地址是程序代碼中定義的函數的名稱(有關更多信息,請參閱ThreadProc)。此函數采用單個參數并返回DWORD值。一個進程可以讓多個線…

location

location (地址): 是瀏覽器 window 上的一個對象,不僅能處理當前頁面的網絡地址,還可以實現頁面間的跳轉 頁面的跳轉: 為什么使用它? 使我們也可以通過腳本語言,也能實現 a 鏈接,同樣的效果&…

linux :Docker 方式 安裝 zookeeper、阿里服務器上 Docker 運行 zookeeper

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 1. 查找官方鏡像,并下載鏡像: # 搜索鏡像: docker search zookeeper# 拉取鏡像:docker …

使用線程池功能

此示例創建自定義線程池,創建工作項和線程池計時器,并將它們與清理組關聯。該池由一個持久性線程組成。它演示了以下線程池函數的使用: CloseThreadpool CloseThreadpoolCleanupGroupCloseThreadpoolCleanupGroupMembersCloseThreadpoolWait…

制動剎車片六個養護要點

剎車片屬于消耗品,在使用中會逐漸磨損,當磨損到極限位置時,必須更換,否則將降低制動的效果,甚至造成安全事故。 制動剎車片關乎生命安全,必須謹慎對待。 大多數轎車采用前盤后鼓式制動器結構,一…

Learn day4 函數參數\變量\閉包\遞歸

1.函數描述 # ### 函數 """ (1)函數的定義:功能 (包裹一部分代碼 實現某一個功能 達成某一個目的) (2)函數特點:可以反復調用,提高代碼的復用性,提高開發效率,便于維護管理 """# (3) 函數的基本格式 """ # 函數的定義處 def fun…

Java 中去除字符串中空格的方法

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 1、方法分類 str.trim(); //去掉首尾空格str.replace(" ",""); //去除所有空格,包括首尾、中間str.re…

使用重定向的輸入和輸出創建子進程

本主題中的示例演示如何使用控制臺進程中的CreateProcess函數創建子進程。它還演示了一種使用匿名管道重定向子進程的標準輸入和輸出句柄的技術。請注意,命名管道也可用于重定向進程I / O. 所述CreatePipe函數使用SECURITY_ATTRIBUTES結構來創建可繼承句柄讀寫兩個…

手動擋停車時掛檔有技巧

徐小姐來電:我家的汽車要年檢了,前幾天,工作人員幫我把車子開進檢測站去檢測,開回來后停在原位上,然后把鑰匙交給我。我拿鑰匙一點火,車子就突然往前動了,根本沒有時間反應,已經撞到…

LOJ 3156: 「NOI2019」回家路線

題目傳送門&#xff1a;LOJ #3156。 題意簡述&#xff1a; 有一張 \(n\) 個點 \(m\) 條邊的有向圖&#xff0c;邊有兩個權值 \(p_i\) 和 \(q_i\)&#xff08;\(p_i<q_i\)&#xff09;表示若 \(p_i\) 時刻在這條邊的起點&#xff0c;則 \(q_i\) 時刻能到達這條邊的終點。 你需…

線程池概述

線程池 一個線程池的工作線程代表應用程序的高效執行異步回調的集合。線程池主要用于減少應用程序線程的數量并提供工作線程的管理。應用程序可以對工作項進行排隊&#xff0c;將工作與可等待的句柄相關聯&#xff0c;根據計時器自動排隊&#xff0c;并與I / O綁定。 線程池架…

WEB 請求處理二:Nginx 請求 反向代理

上一篇《WEB請求處理一&#xff1a;瀏覽器請求發起處理》&#xff0c;我們講述了瀏覽器端請求發起過程&#xff0c;通過DNS域名解析服務器IP&#xff0c;并建立TCP連接&#xff0c;發送HTTP請求。本文將講述請求到達反向代理服務器的一個處理過程&#xff0c;比如&#xff1a;在…

方向盤的正確駕馭方法

如果問您油門踏板和方向盤哪個與駕駛員最“親密”&#xff0c;您會選擇誰呢&#xff1f;恐怕還是方向盤吧。如果汽車行駛過程中您的雙手同時離開了方向盤&#xff0c;那么事故的隱患也就隨之而來。下面我們就為您全面介紹汽車方向盤的正確使用方法。專家介紹&#xff0c;握方向…

SQL server 2005中無法新建作業(Job)的問題

客戶端是使用企業管理其&#xff08;Management Studio&#xff09;新建job&#xff0c;總是無法創建&#xff0c;查找了很多資料&#xff0c;有的說是需要sp2, 但有的又說不是... ... 沒有時間去研究為什么&#xff0c;但確有一種方法解決&#xff1a;到服務器端去創建job&…

線程池API

線程池API 線程池應用程序編程接口&#xff08;API&#xff09;使用基于對象的設計。以下每個對象都由用戶模式數據結構表示&#xff1a; 池對象是一組可用于執行工作的工作線程。每個進程可以根據需要創建具有不同特征的多個隔離池。每個進程都有一個默認池。清理組與一組回…

WEB 請求處理 一:瀏覽器 請求發起處理

最近&#xff0c;終于要把《WEB請求處理系列》提上日程了&#xff0c;一直答應小伙伴們給分享一套完整的WEB請求處理流程&#xff1a;從瀏覽器、Nginx、Servlet容器&#xff0c;最終到應用程序WEB請求的一個處理流程&#xff0c;前段時間由于其他工作事情的安排&#xff0c;一直…

離合器半聯動探秘

離合器踏板作用是切斷發動機和變速箱之間的動力&#xff0c;有利于起步、變速、和停車。那么如何更好的使用它呢&#xff1f; 離合器的五種狀態示意圖 離合器半聯動的使用方法揭密如下&#xff1a; 離合器半聯動的使用探密之一 將離合器抬到車開始動時你就別再抬了&#xff0c;…

Biztalk Server 2006安裝配置

前段時間收到了來自beta.microsoft.com的BTS20006 Beta2的下載地址&#xff0c;這兩天對它進行了一番安裝配置。下面把一些經過和步驟和大家分享一下&#xff0c;手中有一些去年的Biztalk Server2004版本的培訓資料&#xff0c;里面有11個Lab。需要的朋友請留下mail&#xff0c…

apache 官方 Dubbo 文檔

只是分享、記錄一下 dubbo 的文檔地址&#xff1a;apache 官方 Dubbo 文檔 其頁面內容如下&#xff1a;&#xff08;我是用 chrome 直接右鍵翻譯的&#xff0c;原文檔是英文的&#xff09;