當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > embed linux share
[導(dǎo)讀]科普tcp協(xié)議棧對(duì)ping命令處理過(guò)程

知識(shí)回顧

在前面的文章中,我們已經(jīng)介紹了ip數(shù)據(jù)包的封裝接口,其中主要是以下幾個(gè)接口:
  • route_init():路由表的初始化
  • ip_rcv():發(fā)送以太網(wǎng)幀數(shù)據(jù)
  • ip_output():發(fā)送以太網(wǎng)幀數(shù)據(jù) 這幾個(gè)接口是我們封裝IP數(shù)據(jù)接口的基礎(chǔ),最好還是先搞明白原理。

ICMP 協(xié)議的格式

無(wú)論是在宿舍,還是在辦公室,或者運(yùn)維一個(gè)數(shù)據(jù)中心,我們常常會(huì)遇到網(wǎng)絡(luò)不通的問(wèn)題。那臺(tái)機(jī)器明明就在那里,你甚至都可以通過(guò)機(jī)器的終端連上去看。它看著好好的,可是就是連不上去,究竟是哪里出了問(wèn)題呢?一般情況下,你會(huì)想到 ping 一下。
那你知道 ping 是如何工作的嗎?
ping 是基于 ICMP 協(xié)議工作的。ICMP全稱(chēng)Internet Control Message Protocol,就是互聯(lián)網(wǎng)控制報(bào)文協(xié)議。
網(wǎng)絡(luò)包在異常復(fù)雜的網(wǎng)絡(luò)環(huán)境中傳輸時(shí),常常會(huì)遇到各種各樣的問(wèn)題。當(dāng)遇到問(wèn)題的時(shí)候,總不能“死個(gè)不明不白”,要傳出消息來(lái),報(bào)告情況,這樣才可以調(diào)整傳輸策略。這就相當(dāng)于我們經(jīng)常看到的電視劇里,古代行軍的時(shí)候,為將為帥者需要通過(guò)偵察兵、哨探或傳令兵等人肉的方式來(lái)掌握情況,控制整個(gè)戰(zhàn)局。ICMP 報(bào)文是封裝在 IP 包里面的。因?yàn)閭鬏斨噶畹臅r(shí)候,肯定需要源地址和目標(biāo)地址。它本身非常簡(jiǎn)單。因?yàn)樽鳛閭刹楸p裝上陣,不能攜帶大量的包袱。
從而我們可以確定,ICMP是在ip協(xié)議之上的傳輸層協(xié)議,如下圖:


ICMP 報(bào)文有很多的類(lèi)型,不同的類(lèi)型有不同的代碼。最常用的類(lèi)型是主動(dòng)請(qǐng)求為 8,主動(dòng)請(qǐng)求的應(yīng)答為 0。

構(gòu)造ICMP 報(bào)文

接下來(lái),我們使用結(jié)構(gòu)體來(lái)定義ICMP 報(bào)文,該結(jié)構(gòu)體定義在level-ip的include/icmpv4.h文件中:

查詢(xún)報(bào)文類(lèi)型

我們經(jīng)常在電視劇里聽(tīng)到這樣的話(huà):主帥說(shuō),來(lái)人哪!前方戰(zhàn)事如何,快去派人打探,一有情況,立即通報(bào)!
這種是主帥發(fā)起的,主動(dòng)查看敵情,對(duì)應(yīng) ICMP 的查詢(xún)報(bào)文類(lèi)型。例如,常用的ping 就是查詢(xún)報(bào)文,是一種主動(dòng)請(qǐng)求,并且獲得主動(dòng)應(yīng)答的 ICMP 協(xié)議。所以,ping 發(fā)的包也是符合 ICMP 協(xié)議格式的,只不過(guò)它在后面增加了自己的格式。
對(duì) ping 的主動(dòng)請(qǐng)求,進(jìn)行網(wǎng)絡(luò)抓包,稱(chēng)為ICMP ECHO REQUEST。同理主動(dòng)請(qǐng)求的回復(fù),稱(chēng)為ICMP ECHO REPLY。比起原生的 ICMP,這里面多了兩個(gè)字段,一個(gè)是標(biāo)識(shí)符。這個(gè)很好理解,你派出去兩隊(duì)偵查兵,一隊(duì)是偵查戰(zhàn)況的,一隊(duì)是去查找水源的,要有個(gè)標(biāo)識(shí)才能區(qū)分。另一個(gè)是序號(hào),你派出去的偵查兵,都要編個(gè)號(hào)。如果派出去 10 個(gè),回來(lái) 10 個(gè),就說(shuō)明前方戰(zhàn)況不錯(cuò);如果派出去 10 個(gè),回來(lái) 2 個(gè),說(shuō)明情況可能不妙。
在選項(xiàng)數(shù)據(jù)中,ping 還會(huì)存放發(fā)送請(qǐng)求的時(shí)間值,來(lái)計(jì)算往返時(shí)間,說(shuō)明路程的長(zhǎng)短。
當(dāng)前,ICMP還有差錯(cuò)報(bào)文類(lèi)型,適合在遇到各種網(wǎng)絡(luò)故障時(shí)使用,我們這里暫不介紹。

ping:查詢(xún)報(bào)文類(lèi)型的使用

接下來(lái),我們重點(diǎn)來(lái)看 ping 的發(fā)送和接收過(guò)程
  • 主機(jī)A執(zhí)行ping 命令的時(shí)候,源主機(jī)首先會(huì)構(gòu)建一個(gè) ICMP 請(qǐng)求數(shù)據(jù)包,ICMP 數(shù)據(jù)包內(nèi)包含多個(gè)字段。最重要的是兩個(gè),第一個(gè)是類(lèi)型字段,對(duì)于請(qǐng)求數(shù)據(jù)包而言該字段為 8;另外一個(gè)是順序號(hào),主要用于區(qū)分連續(xù) ping 的時(shí)候發(fā)出的多個(gè)數(shù)據(jù)包。每發(fā)出一個(gè)請(qǐng)求數(shù)據(jù)包,順序號(hào)會(huì)自動(dòng)加 1。為了能夠計(jì)算往返時(shí)間 RTT,它會(huì)在報(bào)文的數(shù)據(jù)部分插入發(fā)送時(shí)間。
  • 主機(jī) B 收到這個(gè)數(shù)據(jù)幀后,先檢查它的目的 MAC 地址,并和本機(jī)的 MAC 地址對(duì)比,如符合,則接收,否則就丟棄。接收后檢查該數(shù)據(jù)幀,將 IP 數(shù)據(jù)包從幀中提取出來(lái),交給本機(jī)的 IP 層。同樣,IP 層檢查后,將有用的信息提取后交給 ICMP 協(xié)議。主機(jī) B 會(huì)構(gòu)建一個(gè) ICMP 應(yīng)答包,應(yīng)答數(shù)據(jù)包的類(lèi)型字段為 0,順序號(hào)為接收到的請(qǐng)求數(shù)據(jù)包中的順序號(hào),然后再發(fā)送出去給主機(jī) A。
關(guān)于IP層數(shù)據(jù)收發(fā)和MAC層的數(shù)據(jù)收發(fā)已經(jīng)在前面給大家分析過(guò)了,這里不再講解,我們重點(diǎn)關(guān)注IP數(shù)據(jù)包遞交給ICMP層的過(guò)程。

ICMP數(shù)據(jù)接收接口

ICMP數(shù)據(jù)接收接口為icmpv4_incoming()函數(shù)。該函數(shù)在以太網(wǎng)數(shù)據(jù)幀讀取接口ip_rcv()函數(shù)中調(diào)用。我們來(lái)了解一下這個(gè)函數(shù),如下圖:
第4行:從ip數(shù)據(jù)包中獲取icmp報(bào)文
第8行:判斷icmp的報(bào)文類(lèi)型,如果是查詢(xún)報(bào)文,則調(diào)用icmpv4_reply()函數(shù)

ICMP數(shù)據(jù)發(fā)送接口

ICMP數(shù)據(jù)發(fā)送接口為icmpv4_reply()函數(shù),當(dāng)level-ip協(xié)議棧接受到icmp查詢(xún)類(lèi)型報(bào)文后,會(huì)調(diào)用該接口進(jìn)行ICMP數(shù)據(jù)回復(fù)。如下圖:
第3行:獲取ip數(shù)據(jù)包首部
第8行:用ip數(shù)據(jù)包的總長(zhǎng)度-ip首部長(zhǎng)度,得到icmp包總長(zhǎng)度
第10行:把sk_buff數(shù)據(jù)包指針移動(dòng)到有效數(shù)據(jù)結(jié)束
第11行:把sk_buff數(shù)據(jù)包指針移動(dòng)從有效數(shù)據(jù)的尾巴向前移動(dòng)icmp包總長(zhǎng)度
第13行:獲取icmp數(shù)據(jù)包
第15行:修改icmp協(xié)議類(lèi)型為應(yīng)答類(lèi)型
第16行:把類(lèi)型字段修改為0,表示ping應(yīng)答
第17行:修改校驗(yàn)數(shù)據(jù)
第20行:設(shè)置目標(biāo)主機(jī)ip
第22行:調(diào)用ip數(shù)據(jù)發(fā)送接口,進(jìn)行icmp數(shù)據(jù)包發(fā)送

總結(jié)

通過(guò)我們這邊文章,我們已經(jīng)明白了ICMP協(xié)議的報(bào)文結(jié)構(gòu),并且對(duì)ping命令的處理過(guò)程有了一個(gè)源碼級(jí)別的了解。





本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀(guān)點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉