ARP协议

网络层协议

产生背景:为了实现数据链路层的封装

全称:地址解析协议

作用:根据目的IP地址,请求目的MAC地址。

一、ARP报文

简介

①ARP工作在二层,ARP报文不能穿透路由器,只能在同一广播域传递

②重要字段:发送者MAC、发送者IP、目的MAC、目标IP

③报文类型:ARP请求,ARP应答

ARP报文.png

Hardware Type表示硬件地址类型,一般为以太网;

Protocol Type表示三层协议地址类型,一般为IP;

Hardware Length和Protocol Length为MAC地址和IP地址的长度,单位是字节;

Operation Code指定了ARP报文的类型,包括ARP Request和ARP Reply;

Source Hardware Address指的是发送ARP报文的设备MAC地址;

Source Protocol Address指的是发送ARP报文的设备IP地址;

Destination Hardware Address指的是接收者MAC地址,在ARP Request报文中,该字段值为0;

Destination Protocol Address指的是接收者的IP地址。

1.ARP request报文

ARP请求报文。用于根据目的IP地址请求目的MAC地址。

以太网帧头中:目的MAC为全1.FF-FF-FF-FF-FF-FF.表示ARP请求报文是以广播形式发送。

报文基本格式:
源MAC地址:为单播MAC地址。

​ 源IP地址:为单播IP地址。

​ 目的MAC地址:为全为1,表示未知MAC地址

​ 目的IP地址:为单播IP地址。

2.ARP reply报文

ARP应答报文。用于响应ARP请求报文,应答报文中携带有需要请求的MAC地址。

以太网帧头中:目的MAC为单播,表示以单播的形式回应。

报文格式:

​ 源MAC地址:为单播MAC地址。

​ 源IP地址:为单播IP地址。

​ 目的MAC地址:为单播MAC地址

​ 目的IP地址:为单播IP地址。

二、ARP工作流程

广播请求,单播回复

1.相同网段之间的互访;

ARP请求.png

①当主机A要去访问时主机C时;

首先填充目的MAC,会先查找自己ARP缓存表,如果ARP缓存表没有,则广播发送ARP request报文

②主机C收到主机A的ARP request报文;

会判断请求的目标是否为自己。是,则先记录主机A IP+主机A MAC到ARP缓存表,并单播回复ARP reply报文

主机B收到主机A的ARP request报文,查看DMAC后,发现DMAC!=自己的MAC,会丢弃

ARP响应.png

③主机A收到主机C的ARP reply报文;

记录主机C IP + 主机C MAC到ARP缓存表

④主机A向主机C发送消息

2.不同网段之间的互访(ARP代理);

注意:路由器隔离广播域,不会转发广播的报文,但是会接受,并学习。

ARP代理:路由器将自己的MAC返回给发送ARP广播请求发送者,实现MAC地址代理(善意的欺骗)

微信图片编辑_20200927012141.jpg

当主机A要去访问时主机B时

假设三台设备上ARP缓存表为空

①发送ARP request报文给网关

该请求报文中,目的MAC地址未知,目的IP地址为网关的ip地址。

网关设备会记录主机A IP+主机A MAC到ARP缓存表,

②网关设备回送一个ARP reply报文给主机A,同时发送ARP request报文给主机B

给主机A的 reply报文中,SMAC地址为网关,SIP地址为网关,目的MAC地址为主机A,目的IP地址为主机A。

主机A收到reply报文会记录网关 IP+网关 MAC到ARP缓存表,然后<u>用该目的MAC进行数据包的封装</u>。将数据包发送给到网关。

给主机B 的request报文,SMAC地址为网关,SIP地址为网关,目的MAC地址为未知,目的IP地址为主机B。主机B会将收到的request报文内容记录到ARP缓存表中

③主机B回应ARP reply报文给网关

给网关的reply报文,SMAC地址为主机B,SIP地址为主机B,目的MAC地址为网关,目的IP地址为网关。网光收到reply报文会记录到ARP缓存表中

自此ARP请求结束,自始至终主机A不会得到主机B的MAC地址,主机B同样也不会有主机A的MAC地址,因为在ARP请求过程中网关不会转发一个网段的ARP报文到另一个网段中,而会使用ARP代理功能,告诉主机A:如果你要访问主机B,找我就可以了,我能搞定。

下面这个小实验的图可以体现:

ARP代理1.png

PC0和PC1处于不同网段,PC0 ping PC1后,PC0和PC1的ARP缓存表都只有各自网段网关的ARP条目

三、ARP缓存表的组成

作用

1、用于存放IP地址和MAC地址的对应关系。

2、用于决定访问时,是否需要发送ARP请求报文。

内容

IP + MAC + tpye(学习方式)

查看

在本地cmd上输入如下命令;

arp -a
arp缓存表.png

学习方式:

​ ①动态:通过ARP报文进行学习,存在老化时间,1200s

​ ②静态:通过管理员手动添加IP+MAC,不存在老化时间

​ ③优先级:静态>动态

四、免费ARP

免费ARP报文的<u>源IP地址和目的IP地址相同</u>

免费ARP.png

作用:

检测网络中是否存在IP地址冲突

​ 实现:通过特殊的ARP请求报文(目标IP为自己)进行实现

触发条件:

1.手工配置了IP地址的时候

2.通过DHCP动态获取IP地址时

工作原理:

如果不存在ip地址冲突,就没有回应,如果存在IP地址冲突,那么就会收到ARP的reply报文。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,783评论 5 472
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,396评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,834评论 0 333
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,036评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,035评论 5 362
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,242评论 1 278
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,727评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,376评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,508评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,415评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,463评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,140评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,734评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,809评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,028评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,521评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,119评论 2 341