0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

以太網(wǎng)通信基礎(chǔ)知識(shí)

jf_EksNQtU6 ? 來(lái)源:開心果 Need Car ? 2023-11-22 09:29 ? 次閱讀

開發(fā)以太網(wǎng)的小伙伴,對(duì)ARP(Address Resolution Protocol,地址解析協(xié)議)已經(jīng)見怪不怪。在控制器剛啟動(dòng)階段,總線上會(huì)看到一些ARP報(bào)文。那么,問(wèn)題來(lái)了,為什么在控制器啟動(dòng)階段,會(huì)有ARP報(bào)文呢?ARP報(bào)文到底扮演著什么樣的角色呢?本文,聊一聊ARP。

1、以太網(wǎng)通信基礎(chǔ)

我們知道,以太網(wǎng)是點(diǎn)對(duì)點(diǎn)(Point-to-Point)的通信方式。如果兩個(gè)以太網(wǎng)節(jié)點(diǎn)建立通信,發(fā)送節(jié)點(diǎn)首先需要知道和誰(shuí)通信。發(fā)送節(jié)點(diǎn)如何知道和誰(shuí)通信呢?答:MAC地址(Media Access Control Address)。MAC地址也稱為網(wǎng)卡,每一個(gè)網(wǎng)卡分配唯一MAC地址(長(zhǎng)度為6 Bytes)。所以,知道目標(biāo)節(jié)點(diǎn)MAC地址,才能知道信息要發(fā)給誰(shuí)。而在整車的網(wǎng)絡(luò)拓?fù)渲?,?jié)點(diǎn)之間的數(shù)據(jù)交互由交換機(jī)(Switch)進(jìn)行二層轉(zhuǎn)發(fā),示意如下:

cdcb68f6-886b-11ee-939d-92fbcf53809c.png

(一)ARP幀格式

不管何種總線,為了確保信息有效交互,會(huì)根據(jù)軟、硬件層級(jí),設(shè)計(jì)不同的通信協(xié)議。本文關(guān)注鏈路層的以太網(wǎng)幀和網(wǎng)絡(luò)層的ARP協(xié)議,ARP報(bào)文封裝在以太網(wǎng)幀的數(shù)據(jù)段傳輸,如下所示:

cde6d2c6-886b-11ee-939d-92fbcf53809c.png

硬件類型(2 Byte):表示硬件地址類型,eg:以太網(wǎng)為1

協(xié)議類型(2 Byte):表示上層協(xié)議類型,eg:IPv4為0x0800

硬件地址長(zhǎng)度(1Byte):表示硬件地址長(zhǎng)度,eg:以太網(wǎng)為6

協(xié)議地址長(zhǎng)度(1Byte):表示協(xié)議地址長(zhǎng)度,eg:IPv4為4

操作碼(Option,2 Byte):表示ARP請(qǐng)求或響應(yīng)的操作類型,eg:請(qǐng)求(Request)為1,響應(yīng)(Replay)為2

源MAC地址(6 Byte):發(fā)送ARP請(qǐng)求的主機(jī)的MAC地址

源IP地址(4Byte):發(fā)送ARP請(qǐng)求的主機(jī)的IP地址

目標(biāo)MAC地址(6Byte):目標(biāo)主機(jī)的MAC地址(在ARP請(qǐng)求中通常為空,即:全0x00)

目標(biāo)IP地址(4Byte):目標(biāo)主機(jī)的IP地址

通過(guò)ARP報(bào)文格式可以看出,ARP記錄著IP與MAC的對(duì)應(yīng)關(guān)系,即:通過(guò)IP關(guān)聯(lián)的MAC地址,最終找到通信的目標(biāo)節(jié)點(diǎn)。而在TCP/IP的分層結(jié)構(gòu)中,ARP屬于網(wǎng)絡(luò)層,因此,網(wǎng)絡(luò)層的源節(jié)點(diǎn)實(shí)體、目標(biāo)節(jié)點(diǎn)實(shí)體之間通過(guò)IP地址識(shí)別彼此。但是,ARP報(bào)文封裝在以太網(wǎng)幀中,依賴以太網(wǎng)鏈路層傳輸,而以太網(wǎng)鏈路層的尋址方式為MAC地址,因此,需要把IP地址轉(zhuǎn)換成MAC地址才能將上層待發(fā)送的信息發(fā)送給目標(biāo)節(jié)點(diǎn),所以,這就是ARP出現(xiàn)的意義。 首先,同一局域網(wǎng)內(nèi)的每個(gè)以太網(wǎng)節(jié)點(diǎn),網(wǎng)絡(luò)層會(huì)分配一個(gè)或者多個(gè)IP,數(shù)據(jù)鏈路層固化一個(gè)唯一MAC地址,由標(biāo)識(shí)發(fā)送節(jié)點(diǎn),如下所示:

cdfca826-886b-11ee-939d-92fbcf53809c.png

其次,通過(guò)ARP報(bào)文獲取目標(biāo)節(jié)點(diǎn)的MAC,形成目標(biāo)節(jié)點(diǎn)的對(duì),進(jìn)而,每個(gè)以太網(wǎng)節(jié)點(diǎn)形成一個(gè)ARP Table。有了ARP Table以后,發(fā)送方在發(fā)送數(shù)據(jù)之前,就可以通過(guò)目標(biāo)節(jié)點(diǎn)的IP地址,查找目標(biāo)節(jié)點(diǎn)的MAC地址,進(jìn)而發(fā)送數(shù)據(jù)。每個(gè)節(jié)點(diǎn)的ARP Table示意如下:

ce10138e-886b-11ee-939d-92fbcf53809c.png

(二)交換機(jī)如何轉(zhuǎn)發(fā) ARP Table形成以后,解決了發(fā)送節(jié)點(diǎn)知道發(fā)送給誰(shuí)的問(wèn)題,但是,還有一個(gè)問(wèn)題需要解決:交換機(jī)(Switch)如何知道信息轉(zhuǎn)發(fā)給誰(shuí)呢?:路由表(Route Table),示意如下:

ce405e4a-886b-11ee-939d-92fbcf53809c.png

當(dāng)交換機(jī)某個(gè)端口(Port #n)收到以太網(wǎng)幀以后,會(huì)通過(guò)目標(biāo)節(jié)點(diǎn)的MAC地址查找Route Table,如果找到目標(biāo)節(jié)點(diǎn)端口號(hào),則將信息轉(zhuǎn)發(fā)出去,實(shí)現(xiàn)路由的目的。同時(shí),也會(huì)檢查發(fā)送節(jié)點(diǎn)的MAC地址是否已經(jīng)緩存,如果Route Table中沒有緩存發(fā)送節(jié)點(diǎn)的MAC,則將發(fā)送節(jié)點(diǎn)的MAC地址和入口Port緩存到Route Table。

2、ARP通信原理

(一)

控制器初始啟動(dòng)階段,ARP緩存表為空,即:ARP Table沒有目標(biāo)節(jié)點(diǎn)的信息。此時(shí),發(fā)送節(jié)點(diǎn)發(fā)送ARP報(bào)文,請(qǐng)求目標(biāo)節(jié)點(diǎn)的MAC地址。注意:目標(biāo)節(jié)點(diǎn)的IP地址已知。請(qǐng)求示意如下:

ce449e1a-886b-11ee-939d-92fbcf53809c.png

發(fā)送節(jié)點(diǎn)(MCU2)發(fā)送的ARP報(bào)文信息如下所示:

ce5c1cca-886b-11ee-939d-92fbcf53809c.png

解析:

發(fā)送節(jié)點(diǎn)發(fā)送ARP報(bào)文時(shí),會(huì)包含發(fā)送節(jié)點(diǎn)的IP(192.168.0.2)、發(fā)送節(jié)點(diǎn)MAC(020000:02)、目標(biāo)節(jié)點(diǎn)的IP(192.168.0.1);

由于不知道目標(biāo)節(jié)點(diǎn)的MAC,所以,在ARP報(bào)文中,目標(biāo)節(jié)點(diǎn)的MAC地址(上圖中的Target Protocol Address)用全0x00表示;

由于發(fā)送節(jié)點(diǎn)不知道目標(biāo)節(jié)點(diǎn)在哪個(gè)位置,所以,發(fā)送節(jié)點(diǎn)發(fā)送ARP請(qǐng)求時(shí),使用廣播的方式發(fā)送,即:Destination為全0xFF。

(二)

當(dāng)交換機(jī)收到MCU2的ARP請(qǐng)求報(bào)文以后,發(fā)現(xiàn):路由表中找不到目標(biāo)節(jié)點(diǎn)的Port(初始階段為空),于是,交換機(jī)向所有端口廣播ARP報(bào)文(不包含接收端口),同時(shí),緩存MCU2的MAC2和Port2,如下所示:

ce6acab8-886b-11ee-939d-92fbcf53809c.png

(三)

當(dāng)目標(biāo)節(jié)點(diǎn)(MCU1)收到ARP請(qǐng)求報(bào)文以后,發(fā)現(xiàn)MAC地址與自身匹配,則接收該ARP報(bào)文,同時(shí)將發(fā)送節(jié)點(diǎn)的MAC2緩存下來(lái)。MCU1之后給出ARP響應(yīng),由于知道了發(fā)送節(jié)點(diǎn)的MAC地址,所以,MCU1響應(yīng)ARP報(bào)文時(shí),單播發(fā)送ARP報(bào)文。當(dāng)交換機(jī)收到MCU1的ARP響應(yīng)以后,發(fā)現(xiàn)目標(biāo)節(jié)點(diǎn)是MCU2,而且MCU2的MAC2已經(jīng)關(guān)聯(lián)Port2,則直接將ARP報(bào)文發(fā)送給MCU2,同時(shí),交換機(jī)緩存。當(dāng)MCU1接收到MCU2的ARP響應(yīng)以后,也會(huì)緩存。之后,MCU1和MCU2即可正常通信,示意如下:

ce823338-886b-11ee-939d-92fbcf53809c.png

提示:非目標(biāo)節(jié)點(diǎn)收到ARP報(bào)文以后,直接丟棄。

響應(yīng)節(jié)點(diǎn)(MCU1)發(fā)送的ARP報(bào)文信息如下所示:

cea3901e-886b-11ee-939d-92fbcf53809c.png

解析: ARP響應(yīng)報(bào)文屬于單播。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 控制器
    +關(guān)注

    關(guān)注

    112

    文章

    15879

    瀏覽量

    175342
  • 以太網(wǎng)
    +關(guān)注

    關(guān)注

    40

    文章

    5287

    瀏覽量

    169637
  • 通信
    +關(guān)注

    關(guān)注

    18

    文章

    5878

    瀏覽量

    135308
  • Mac
  • ARP
    ARP
    +關(guān)注

    關(guān)注

    0

    文章

    50

    瀏覽量

    14705

原文標(biāo)題:以太網(wǎng)基礎(chǔ):為什么需要ARP?

文章出處:【微信號(hào):談思實(shí)驗(yàn)室,微信公眾號(hào):談思實(shí)驗(yàn)室】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    以太網(wǎng)通信S7是什么意思?

    以太網(wǎng)通信
    YS YYDS
    發(fā)布于 :2023年06月25日 00:07:18

    stm32STM32F4+DP83848以太網(wǎng)通信指南

    17:32:19以太網(wǎng)通信stm32STM32F4+DP83848以太網(wǎng)通信指南系列(一):知識(shí)儲(chǔ)備前言:項(xiàng)目需求使用STM32F407進(jìn)行以太網(wǎng)通信,并涉及到數(shù)據(jù)鏈路層的工業(yè)
    發(fā)表于 08-03 07:02

    基于ARM的多路串行和以太網(wǎng)通信技術(shù)的研究與應(yīng)用

    本文主要是對(duì)于多路串行和以太網(wǎng)通信技術(shù)的介紹,以及基于ARM的多路串行和以太網(wǎng)通信技術(shù)的研究與應(yīng)用
    發(fā)表于 10-17 17:41 ?76次下載
    基于ARM的多路串行和<b class='flag-5'>以太網(wǎng)通信</b>技術(shù)的研究與應(yīng)用

    使用 CCM 導(dǎo)致以太網(wǎng)通信失敗問(wèn)題

    STM32使用 CCM 導(dǎo)致以太網(wǎng)通信失敗
    發(fā)表于 11-25 14:45 ?0次下載

    EtherCAT的工業(yè)以太網(wǎng)通信芯片的設(shè)計(jì)

    本文檔內(nèi)容介紹了EtherCAT的工業(yè)以太網(wǎng)通信芯片的設(shè)計(jì)。
    發(fā)表于 09-15 10:18 ?16次下載
    EtherCAT的工業(yè)<b class='flag-5'>以太網(wǎng)通信</b>芯片的設(shè)計(jì)

    DSP_BIOS在以太網(wǎng)通信節(jié)點(diǎn)中的應(yīng)用

    DSP_BIOS在以太網(wǎng)通信節(jié)點(diǎn)中的應(yīng)用
    發(fā)表于 10-20 11:03 ?2次下載
    DSP_BIOS在<b class='flag-5'>以太網(wǎng)通信</b>節(jié)點(diǎn)中的應(yīng)用

    S7-200SMART開放以太網(wǎng)通信

    此文重點(diǎn)介紹V2.2最新升級(jí)的功能開放以太網(wǎng)通信功能,用過(guò)GET/PUT通信的肯定覺得非常方便,唯一的遺憾就是只支持S7協(xié)議,無(wú)法實(shí)現(xiàn)和其它品牌產(chǎn)品進(jìn)行以太網(wǎng)通信,開放的以太網(wǎng)通信就是
    的頭像 發(fā)表于 06-27 09:58 ?1.9w次閱讀

    關(guān)于工業(yè)以太網(wǎng)通信的解決方案介紹

    瑞薩電子工業(yè)以太網(wǎng)通信解決方案
    的頭像 發(fā)表于 07-23 00:43 ?4003次閱讀

    Xilinx平臺(tái)以太網(wǎng)接口(一)TCP/IP基礎(chǔ)

    在完成以太網(wǎng)通信實(shí)驗(yàn)之前,必須要對(duì)以太網(wǎng)基礎(chǔ)知識(shí)進(jìn)行了解。時(shí)間充裕的可以看看《圖解TCP/IP》作為掃盲。本文重點(diǎn)對(duì)以太網(wǎng)幀結(jié)構(gòu)進(jìn)行介紹。
    的頭像 發(fā)表于 02-19 17:54 ?2196次閱讀
    Xilinx平臺(tái)<b class='flag-5'>以太網(wǎng)</b>接口(一)TCP/IP基礎(chǔ)

    簡(jiǎn)化您的以太網(wǎng)設(shè)計(jì),第1部分:以太網(wǎng)PHY基礎(chǔ)知識(shí)和選擇過(guò)程

    簡(jiǎn)化您的以太網(wǎng)設(shè)計(jì),第1部分:以太網(wǎng)PHY基礎(chǔ)知識(shí)和選擇過(guò)程
    發(fā)表于 10-31 08:23 ?1次下載
    簡(jiǎn)化您的<b class='flag-5'>以太網(wǎng)</b>設(shè)計(jì),第1部分:<b class='flag-5'>以太網(wǎng)</b>PHY<b class='flag-5'>基礎(chǔ)知識(shí)</b>和選擇過(guò)程

    以太網(wǎng)通信和串口通信區(qū)別

    以太網(wǎng)通信和串口通信區(qū)別? 以太網(wǎng)通信和串口通信都是網(wǎng)絡(luò)通信中常見的方式,在實(shí)際應(yīng)用中,兩者的使用場(chǎng)景各有不同。
    的頭像 發(fā)表于 09-02 14:44 ?5369次閱讀

    基于FPGA的UDP RGMII千兆以太網(wǎng)通信方案

    本文介紹一個(gè)FPGA開源項(xiàng)目:UDP RGMII千兆以太網(wǎng)通信。該項(xiàng)目在我之前的工作中主要是用于FPGA和電腦端之間進(jìn)行圖像數(shù)據(jù)傳輸。本文簡(jiǎn)要介紹一下該項(xiàng)目的千兆以太網(wǎng)通信方案、以太網(wǎng)IP核的使用以及Vivado工程源代碼結(jié)構(gòu)。
    的頭像 發(fā)表于 09-04 16:49 ?1346次閱讀
    基于FPGA的UDP RGMII千兆<b class='flag-5'>以太網(wǎng)通信</b>方案

    串行通信以太網(wǎng)通信,該怎么選才好?

    串行通信以太網(wǎng)通信都通過(guò)有線傳輸數(shù)據(jù),但各自有不同的用途。串行通信以太網(wǎng)通信的主要區(qū)別在于:串行通信是通過(guò)串行
    的頭像 發(fā)表于 12-22 08:20 ?862次閱讀
    串行<b class='flag-5'>通信</b>和<b class='flag-5'>以太網(wǎng)通信</b>,該怎么選才好?

    工業(yè)以太網(wǎng)通信協(xié)議的主要類別

    隨著工業(yè)4.0和智能制造的快速發(fā)展,工業(yè)以太網(wǎng)通信協(xié)議與標(biāo)準(zhǔn)在工業(yè)自動(dòng)化領(lǐng)域扮演著越來(lái)越重要的角色。工業(yè)以太網(wǎng)不僅提供了高效、可靠的數(shù)據(jù)傳輸手段,還為實(shí)現(xiàn)設(shè)備間的無(wú)縫集成和信息共享提供了可能。本文將詳細(xì)介紹工業(yè)以太網(wǎng)通信協(xié)議與標(biāo)
    的頭像 發(fā)表于 06-28 18:02 ?823次閱讀

    以太網(wǎng)通信網(wǎng)關(guān)是什么

    在日益復(fù)雜的網(wǎng)絡(luò)環(huán)境中,以太網(wǎng)通信網(wǎng)關(guān)作為連接不同設(shè)備和網(wǎng)絡(luò)的橋梁,扮演著至關(guān)重要的角色。本文將深入探討以太網(wǎng)通信網(wǎng)關(guān)的定義、功能、工作機(jī)制及其在各個(gè)領(lǐng)域的應(yīng)用。 一、以太網(wǎng)通信網(wǎng)關(guān)的定義
    的頭像 發(fā)表于 08-29 14:04 ?131次閱讀
    <b class='flag-5'>以太網(wǎng)通信</b>網(wǎng)關(guān)是什么