查缺补漏----IP通信过程

1.DHCP协议

H3刚接入网络时,只知道自己的MAC地址,所以需要通过DHCP协议请求自己的IP地址。

通过DHCP协议,得到IP地址、子网掩码、网关与DNS服务器IP地址。

DHCP协议是应用层协议(传输层为UDP),请求报文是广播 (H3不知道DHCP服务器的IP地址),响应报文是广播(因为H3此时还没有IP地址)。一台主机得到IP地址、子网掩码、网关后,才认为它正确的接入了该网络。

2.DNS协议

若主机想要访问一个网站,只知道对方的域名,那么需要通过DNS协议请求目的IP地址。此时要通过ARP协议将本地DNS服务器的IP地址解析为对应的MAC地址,这样才能进行数据传输。

①若主机已知对方IP地址,那不需要进行DNS查询。

②只知道对方的域名,通过DNS协议请求目的IP地址。

DNS协议是应用层协议(传输层为UDP),分为递归查询和递归迭代查询,一般采用递归迭代查询(主机向本地DNS服务器发出请求为递归,本地DNS服务器向其他域名服务器发请求,为迭代)。

有几级域名,本地DNS服务器就需要查找几次其他域名服务器(四级域名需要查询1次根、1次顶级、2次权限)

答案:C

3.ARP协议

接下来需要知道目的MAC地址(下一跳的MAC地址),首先根据自己与对方的网络号判断是否在同一个网段。

网络号=子网掩码和IP地址进行与操作,判断(目的IP 与 本主机子网掩码)和(源IP与本主机子网掩码)是否相等情况

①:两者相同,说明在同一个子网;此时两主机的通信是在同一个子网内的,下一跳就是目的主机。

情况②:两者不同,说明不在同一个子网;每一个网段需要一次ARP请求,故需要多次ARP协议。在第一轮,源主机会发送链路层广播,请求网关MAC地址(源主机会将这个MAC地址存入ARP表中,之后与网关的通信就不需要发送ARP请求了),之后每个网段都是如此。

当目的主机收到了离他最近的网关的链路层广播,就会单播回应,这时网关就可以将源主机发给目的主机的帧转发给目的主机了。

以数据帧从H3发送到H1为例:

它跨越了路由器,所以可以分为两段:H3->R1和R1->H1

① 如果在同一子网则下一跳就是目的主机,ARP请求的是目的主机的MAC地址;

② 如果不在同一子网则下一跳是网关,ARP请求的是网关的MAC地址

如果没有NAT路由器,源,目的IP地址在传输过程中不变,而针对MAC地址,只要跨越了网段就需要改变源和目的MAC地址。

4.NAT路由器

对于跨网段的通信,发送方发出的报文,源址是自己的IP地址,目的地址填对方的外部IP地址(即通过NAT转换的地址)

经过NAT路由器时,如果是内一>外: 则改变源IP地址;如果是外一>内:则改变目的IP地址。

:在改变NAT地址的同时,也会改变端口号,这个端口号是NAT服务器分配的,这说明NAT路由器是网络层之上的设备,而普通的路由器是网络层的设备。

例题:

相关推荐
DianSan_ERP10 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅10 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
2501_9462055210 天前
晶圆机器人双臂怎么选型?适配2-12寸晶圆的末端效应器有哪些?
服务器·网络·机器人
linux kernel10 天前
第七部分:高级IO
服务器·网络
数字护盾(和中)10 天前
BAS+ATT&CK:企业主动防御的黄金组合
服务器·网络·数据库
~远在太平洋~10 天前
Debian系统如何删除多余的kernel
linux·网络·debian
unfeeling_10 天前
Keepalived实验
linux·服务器·网络
坐吃山猪10 天前
OpenClaw04_Gateway常见问题
网络·gateway·openclaw
上海云盾商务经理杨杨10 天前
2025年重大网络安全事件回顾与趋势分析
网络·安全·web安全
kylezhao201910 天前
C# 的开闭原则(OCP)在工控上位机开发中的具体应用
网络·c#·开闭原则