成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

輕松應對百萬并發的Nginx,你知道它是怎么處理這些網絡事件的嗎?

運維 系統運維
在深入了解 Nginx 各種原理及在極端場景下的一些錯誤場景處理時,需要首先理解什么是網絡事件。

 [[312036]] 

Nginx 是一個事件驅動的框架,所謂事件主要指的是網絡事件,Nginx 每個網絡連接會對應兩個網絡事件,一個讀事件一個寫事件。在深入了解 Nginx 各種原理及在極端場景下的一些錯誤場景處理時,需要首先理解什么是網絡事件。

網絡傳輸

 

接下來看上面這張圖,比如主機 A 就是一臺家里的筆記本電腦,那么主機 B 就是一臺服務器,上面跑著 Nginx 服務。從主機 A 發送一個 HTTP 的 GET 請求到主機 B,這樣的一個過程中主要經歷了哪些事件?通過上圖數據流部分可以看出:

應用層里發送了一個 GET 請求 -> 到了傳輸層,這一步主要在做一件事,就是瀏覽器打開了一個端口,在 windows 的任務管理器中可以看到這一點,他會把這個端口記下來以及把 Nginx 打開的端口比如 80 或者 443 也記到傳輸層 -> 然后在網絡層會記下我們主機所在的 IP 和目標主機,也就是 Nginx 所在服務器公網 IP -> 到鏈路層以后 -> 經過以太網 -> 到達家里的路由器(網絡層),家中的路由器會記錄下所在運營商的一些下一段的 IP -> 通過廣域網 -> 跳轉到主機 B 所在的機器中 -> 報文會經過鏈路層 -> 網絡層 -> 到傳輸層,在傳輸層操作系統就知道是給那個打開了 80 或者 443 的進程,這個進程自然就是 Nginx -> 那么 Nginx 在他的 HTTP 狀態處理機里面(應用層)就會處理這個請求。

在上述過程中網絡報文扮演了一個怎樣的角色呢?

TCP流與報文

 

數據鏈路層會在數據的前面 Header 部分和 Footer 部分添加上源 MAC 地址和源目的地址 -> 到了網絡層則是 Nginx 的公網地址(目的 IP 地址)和瀏覽器的公網地址(源 IP 地址)-> 到了 TCP 層(傳輸層),指定了 Nginx 打開的端口(目的端口)和瀏覽器打開的端口(源端口)-> 然后應用層就是 HTTP 協議了。

這就是一個報文,也就是說我們發送的 HTTP 協議會被切割成很多小的報文,在網絡層會切割叫 MTU,以太網的每個 MTU 是 1500 字節;在 TCP 層(傳輸層)呢會考慮中間每個環節中最大的一個 MTU 值,這個時候往往每個報文只有幾百字節,這個報文大小我們稱為叫 MSS ,所以每收到一個 MSS 小于這么大小的一個報文時其實就是一個網絡事件。

這個時候,我們來看下 TCP 協議中許多事件是怎樣和我們日常調用的一些接口(比如Accept、Read、Write、Close)是怎樣關聯在一起的?

TCP 協議與非阻塞接口

 

請求建立 TCP 連接事件實際上是發送了一個 TCP 報文,通過上面第二部分講解的那樣的一個流程到達了 Nginx,對應的是讀事件。因為對于 Nginx 來說,我讀取到了一個報文,所以就是 Accept 建立鏈接事件。

如果是 TCP 連接可讀事件,就是發送了一個消息,對于 Nginx 也是一個讀事件,就是 Read 讀消息。

如果是對端(也就是瀏覽器)主動地關掉了,相當于 windows 操作系統會去發送一個要求關閉鏈接的一個事件,對于 Nginx 來說還是一個讀事件,因為他只是去讀取一個報文。

那什么是寫事件呢?當我們的瀏覽器需要向瀏覽器發送響應的時候,需要把消息寫到操作系統中,要求操作系統發送到網絡中,這就是一個寫事件。

像這樣的一些網絡讀寫事件,通常在 Nginx 中或者任何一個異步事件的處理框架中,他會有個東西叫事件收集、分發器。會定義每類事件處理的消費者,也就是說事件是一個生產者,是通過網絡中自動的生產到我們的 Nginx 中的,我們要對每種事件建立一個消費者。比如連接建立事件消費者,就是對 Accept 調用,HTTP 模塊就會去建立一個新的連接。還有很多讀消息或者寫消息,在 HTTP 狀態機中不同的時間段會調用不同的方法也就是每個消費者處理。

以上就是一個事件分發、消費器,包括 AIO 像異步讀寫磁盤事件,還有定時器事件,比如是否超時(worker_shutdown_timeout)。

Nginx 網絡事件實例

上面介紹了網絡報文的發送以及對應的 Nginx 中的網絡事件,比如 Accept 建立一條新連接其實是收到一條讀事件,接下來我們通過抓包來分析建立三次握手時時怎么樣讓 Nginx 收到讀事件,使用的抓包工具是 Wireshark。

 

首先我們安裝 Wireshark 軟件,并對 Nginx 所在 IP 和端口進行抓包,然后訪問頁面,在 TCP 層主要說兩件事情:

•瀏覽器首先會打開這個頁面,本地打開了一個 1875 端口,而 Nginx 啟動的是 8080 端口。

•TCP 層主要做的是進程與進程之間通訊這件事。

 

IP 層主要解決機器與機器之間怎樣互相找到的問題。

 

三次握手也就是 windows 先向 Nginx 發送了一次 [SYN],那么相反的 Nginx 所在的服務器也會向 windows 發送一個 [SYN],這個時候 Nginx 是沒有感知到的,因為這個連接還是處于半打開的狀態。直到這臺 windows 服務器再次發送 [ACK] 到 Nginx 所在的服務器之上時,Nginx 所在的操作系統才會去通知 Nginx 我們收到了一個讀事件,這個讀事件對應是建立一個新連接,所以此時 Nginx 應該調用 Accept 方法去建立一個新的連接。

以上我們通過 Wireshark 抓包演示了正常的三次握手是怎么樣引發一個讀事件來使得 Nginx 去處理這樣一個讀事件來建立新的連接的。

總結

這篇文章主要講解了網絡事件,并通過抓包來分析 Nginx 網絡事件,這對我們理解 Nginx 異步處理框架是非常有幫助的,包括 OpenResty 也是強依賴于網絡事件以及事件分發的。

 

責任編輯:龐桂玉 來源: 運維之美
相關推薦

2023-01-28 10:27:04

2022-10-14 18:19:41

YouTube

2023-01-16 08:09:51

SpringMVC句柄

2023-10-23 09:44:00

并發管理線程

2020-12-04 08:32:12

Linux特殊名字

2018-06-27 09:51:17

2019-09-23 08:46:04

零拷貝 CPU內存

2020-07-06 12:09:24

DNS域名系統IP地址

2021-08-05 18:21:29

Autowired代碼spring

2024-01-31 08:50:41

Guava并發工具

2018-05-11 15:53:59

2019-07-03 14:34:39

Docker云計算技術

2017-01-17 10:09:22

Linux操作系統應用程序

2019-09-19 17:38:10

5G技術人生第一份工作

2020-09-17 16:08:29

網絡安全數據技術

2016-03-18 19:03:35

認知計算IBM

2021-11-10 15:37:49

Go源碼指令

2018-08-07 09:29:35

數據庫MySQL優化方法

2022-11-10 09:00:41

2020-12-08 09:28:26

Chrome函數代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品区一区二区三区 | 成人免费视频网站在线观看 | 天天躁日日躁狠狠躁2018小说 | 国产精品免费视频一区 | 欧美精品在线一区 | 亚洲欧美一区二区三区国产精品 | 国产一区二区欧美 | 国产欧美一区二区三区久久手机版 | 99国产精品久久久 | 风间由美一区二区三区在线观看 | 日本免费网 | 欧美性另类 | 欧美精品久久久久 | 嫩草一区二区三区 | 国产精品三级 | 毛片免费观看视频 | 国产精品国产三级国产aⅴ中文 | 中文字幕亚洲精品 | 欧美精品一区二区三区在线播放 | 色呦呦在线 | 久久国产欧美一区二区三区精品 | 欧美一区二区三区视频 | 欧美bondage紧缚视频 | 日韩在线一区二区 | 精国产品一区二区三区 | 欧美日韩久久 | 国产精品夜夜春夜夜爽久久电影 | 少妇淫片aaaaa毛片叫床爽 | 久久99精品国产99久久6男男 | 新91视频网| 欧美成人一区二区 | 久久久久久久久国产 | 亚洲欧美综合精品另类天天更新 | 亚洲视频一区二区三区四区 | 精品一区二区在线看 | 成人h视频在线观看 | 一区二区三区视频免费看 | 在线播放精品视频 | 黄色毛片一级 | 女女百合av大片一区二区三区九县 | 亚洲精品欧美 |