Linux 網絡--TCP協議收包流程(NAPI機制)

Linux 網絡--TCP協議收包流程(NAPI機制)

平臺環境簡介
宿主機: ubuntu18.04
Linux內核源碼版本: Linux-4.15
網卡驅動: Intel e1000 (ubuntu 虛擬機默認網卡驅動)
協議:TCP協議,本文分析收包過程

本文以 Linux4.15 內核版本對TCP協議的網絡數據包接收處理過程進行分析。

NAPI機制引入
New API(NAPI)是 Linux 上采用的一種提高網絡處理效率的技術,它的核心概念就是不采用中斷的方式讀取數據,而代之以首先采用中斷喚醒數據接收的服務程序,然后 POLL 的方法來輪詢數據。隨著網絡的接收速度的增加,NIC 觸發的中斷能做到不斷減少,目前 NAPI 技術已經在網卡驅動層和網絡層得到了廣泛的應用,驅動層次上已經有 E1000 系列網卡,RTL8139 系列網卡,3c50X 系列等主流的網絡適配器都采用了這個技術,而在網絡層次上,NAPI 技術已經完全被應用到了著名的netif_rx 函數中間,并且提供了專門的 POLL 方法--process_backlog 來處理輪詢的方法;根據實驗數據表明采用NAPI技術可以大大改善短長度數據包接收的效率,減少中斷觸發的時間。

OSI七層模式和TCP/IP四層模型
進入正題前,我們先重溫一下TCP/IP模型以及對應Linux系統的各部分功能。

數據包流轉

函數調用流程 您粘貼的區域不支持圖片插入。

1.系統調用

應用程序調用read()阻塞等待讀取網絡數據,通過sk_wait_data()進行阻塞,當有數據到來時,觸發等待隊列,調用skb_copy_datagram_msg()進行數據拷貝。具體函數調用流程如下所示:

=>read() 系統調用
=>vfs_read()
=>new_sync_read()
=>call_read_iter()
=>sock_recvmsg() 進入sock接收
=>sock_recvmsg_nosec()
=>inet_recvmsg()
=>tcp_recvmsg() 阻塞,進入tcp協議棧
?=>sk_wait_data() 等待數據到來
?=>skb_copy_datagram_msg() 數據來了拷貝

2.網卡中斷處理函數

當網卡收到數據時,通過e1000網卡驅動綁定的 e1000_intr() 中斷函數進行處理,因為e1000網卡支持NAPI機制,所以進入__napi_schedule()進行觸發,將當前節點加入napi_poll鏈表并觸發軟中斷進入 NAPI處理 。中斷函數的調用流程如下所示:

=> irqreturn_t e1000_intr(int irq, void *data) 中斷處理函數
=> __napi_schedule(&adapter->napi) 調度NAPI
=> ____napi_schedule() NAPI調度
? =>list_add_tail(&napi->poll_list,&sd->poll_list);添加到poll鏈表
? =>__raise_softirq_irqoff(NET_RX_SOFTIRQ); 觸發軟中斷

3.NAPI處理

=> invoke_softirq() 軟中斷
=> __do_softirq()
=> net_rx_action()
=> napi_poll() 執行NAPI機制
=> e1000_clean()
=> e1000_clean_rx_irq()
=> e1000_copybreak() 拷貝數據
?=>e1000_alloc_rx_skb() 申請skb內存
?=>dma_sync_single_for_cpu() 同步DMA數據
?=>skb_put_data() 拷貝DMA數據到SKB
=> e1000_receive_skb()
=> napi_gro_receive()
=> napi_skb_finish()
=> netif_receive_skb_internal()
=> __netif_receive_skb()
=> __netif_receive_skb_core()

=> ip_rcv() 進入網絡層
=> ip_rcv_finish()
=> dst_input()
=> ip_local_deliver()
=> ip_local_deliver_finish()
=> tcp_v4_rcv()
=> tcp_v4_do_rcv()
?=> tcp_rcv_established()
?=> sk_data_ready() 喚醒等待隊列
=> tcp_add_backlog()
=> release_sock()喚醒

總結

注: 不同的Linux內核版本,可能函數名不太一樣,但是總體流程是一樣的,可參考進行分析。

通過對網絡收包過程的梳理,讓我們對Linux網絡數據包的流轉有一定的概念,在需要分析源碼的時候能找到對應位置進行分析。

我是小C,歡迎大家一起交流學習,請關注、點贊、在看吧,不定期分享技術干活哦。

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

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

相關文章

緩存新境界:Eureka中服務的分布式緩存實現策略

緩存新境界:Eureka中服務的分布式緩存實現策略 引言 在微服務架構中,服務間的通信和數據交換頻繁,引入分布式緩存可以顯著提高系統性能和響應速度。Eureka作為Netflix開源的服務發現框架,雖然本身不提供緩存機制,但可…

【線程狀態-2】

1、線程禮讓 (1)禮讓線程,讓當前正在執行的線程暫停,但不阻塞 (2)將線程從運行狀態轉為就緒狀態 (3)讓cpu重新調度,禮讓不一定成功!看cpu心情 package st…

單對以太網:工業4.0時代的通信革命

單對以太網連接器概述 單對以太網(Single Pair Ethernet,簡稱SPE)是一種新興的以太網技術,它通過一對雙絞線實現數據傳輸,支持PoDL(Power over Data Line)技術,為終端設備提供電力供…

【AI工具介紹】— webkit簡介

目錄 一、起源與發展 二、核心組件與功能 三、特性與優勢 四、應用與影響 五、結論 一、起源與發展 WebKit起源于蘋果公司,最初是為了開發Safari瀏覽器而創建的。WebKit項目的起源可以追溯到蘋果公司在2001年推出基于Unix的操作系統Mac OS X時,對瀏…

windows JDK11 與JDK1.8自動切換,以及切換后失效的問題

1.windows安裝不同環境的jdk 2.切換jdk 3.切換失敗 原因:這是因為當我們安裝并配置好JDK11之后它會自動生成一個環境變量(此變量我們看不到),此環境變量優先級較高,導致我們在切換回JDK8后系統會先讀取到JDK11生成的…

Java項目:基于SSM框架實現的中小型企業財務管理系統【ssm+B/S架構+源碼+數據庫+答辯PPT+開題報告+畢業論文】

一、項目簡介 本項目是一套基于SSM框架實現的中小型企業財務管理系統 包含:項目源碼、數據庫腳本等,該項目附帶全部源碼可作為畢設使用。 項目都經過嚴格調試,eclipse或者idea 確保可以運行! 該系統功能完善、界面美觀、操作簡單…

Spark實現電商消費者畫像案例

作者/朱季謙 故事得從這一張圖開始說起—— 可憐的打工人準備下班時,突然收到領導發來的一份電商消費者樣本數據,數據內容是這樣的—— 消費者姓名|年齡|性別|薪資|消費偏好|消費領域&#x…

CentOS 7:停止更新后如何下載軟件?

引言 CentOS 7 是一個廣受歡迎的 Linux 發行版,它為企業和開發者提供了一個穩定、安全、且免費的操作系統環境。然而,隨著時間的推移,CentOS 7 的官方支持已經進入了維護階段,這意味著它將不再收到常規的更新和新功能,…

圖像類別生成數字標簽

類別 COCO 2017數據集分類標簽。coco2017數據集下載。 cls [background, person, bicycle, car, motorcycle, airplane, bus,train, truck, boat, traffic light, fire hydrant,stop sign, parking meter, bench, bird, cat, dog,horse, sheep, cow, elephant, bear, zebra,…

2024建博會|博聯AI大模型全屋智能引領智能體驗新紀元

7月8日,2024中國建博會(廣州)在廣交會展館及保利世貿博覽館盛大啟幕。BroadLink博聯智能攜AI大模型全屋智能以及AI商業照明解決方案驚喜亮相,全方位展示AI大模型在智能家居領域的前沿應用成果。 本次建博會,博聯智能帶…

java.lang.annotation包介紹

java.lang.annotation 包是 Java 標準庫中的一個核心包,專門用于定義和支持 Java 注解(Annotation)。該包中包含了一些核心的接口和枚舉類型,用于定義和控制注解在 Java 程序中的行為和使用方式。 主要的類和接口 Annotation 接口 java.lang.annotation.Annotation 所有注…

NPDP含金量高嗎?什么人適合學習NPDP?

PMP考完了,最近在考NPDP,這也是一個有意思的證書,含金量還不錯,非常適合想轉型和升級的人來考。 一、NPDP是什么 NPDP其實就是產品經理國際資格認證(New Product Development Professional),是…

C++慣用法: 通過std::decltype來SFINAE掉表達式

目錄 1.什么是SFINAE 2.SFINAE(替換失敗不是錯誤) 3.通過std::decltype來SFINAE掉表達式 1.什么是SFINAE SFINAE 技術,即匹配失敗不是錯誤,英文Substitution Failure Is Not An Error,其作用是當我們在進行模板特化的時候,會去…

嵌入式c語言——指針加修飾符

指針變量可以用修飾符來修飾

量化交易常用名詞介紹(七)——模塊篇

目錄 七、模塊篇 1. NumPy 2. pandas 3. matplotlib 4. scikit-learn 5. TensorFlow 6. TA-Lib 7. statsmodels 8. Backtrader 9. PyPortfolioOpt 10. Zipline 七、模塊篇 在量化交易中,Python 及其豐富的庫生態系統提供了強大的支持。以…

Redis部署和基礎命令

一、Redis基本概念 1.1 Redis簡介 Redis(遠程字典服務器) 是一個開源的、使用 C 語言編寫的 NoSQL 數據庫。 Redis 基于內存運行并支持持久化,采用key-value(鍵值對)的存儲形式,是目前分布式架構中不可或…

python爬蟲之scrapy基于管道持久化存儲操作

python爬蟲之scrapy基于管道持久化存儲操作 本文基于python爬蟲之基于終端指令的持久化存儲和python爬蟲之數據解析操作而寫 scrapy持久化存儲 基于管道: 編碼流程: 1、數據解析 2、在item類中定義相關屬性 3、將解析的數據封裝存儲到item類型的對象 4、…

Linux內核 -- 內存管理之scatterlist結構使用

Linux Kernel Scatterlist 使用指南 1. 簡介 scatterlist 結構在 Linux 內核中主要用于 DMA(直接內存訪問)操作中的內存管理。它允許將不連續的物理內存片段表示為一個邏輯上的連續塊,從而使 DMA 操作可以高效地處理這些不連續的內存片段。…

【問題記錄】VsCode中以管理員權限運行Powershell

問題展示 今天在嘗試運行nodemon命令的時候出問題,顯示沒法識別,經過分析發現是管理員權限的問題,由于是在vscode里面進行開發,因此特此進行配置。 方法一 直接在vscode命令行中輸入如下命令: Start-Process powers…

IDEA如何創建原生maven子模塊

文件 -> 新建 -> 新模塊 -> Maven ArcheTypeMaven ArcheType界面中的輸入框介紹 名稱:子模塊的名稱位置:子模塊存放的路徑名創建Git倉庫:子模塊不單獨作為一個git倉庫,無需勾選JDK:JDK版本號父項:…