查缺补漏----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路由器是网络层之上的设备,而普通的路由器是网络层的设备。

例题:

相关推荐
2345VOR20 分钟前
【创龙RK3576开发板与电脑直连网络配置指南】
网络·电脑
qqssss121dfd32 分钟前
计算机网络(第8版,谢希仁)第二章习题解答
服务器·网络·计算机网络
是店小二呀35 分钟前
本地 Websocket 调试总碰壁?cpolar一招让远程访问变简单
网络·websocket·网络协议
阿巴~阿巴~1 小时前
解锁HTTP方法奥秘:GET与POST的深度探索与实战演示
服务器·网络·网络协议·http·get·post·请求方法
小许学java1 小时前
网络编程套接字
java·网络·udp·socket·tcp·套接字
inquisiter1 小时前
cove-salus-tellus测试程序时序逻辑
linux·服务器·网络·riscv
代码不行的搬运工1 小时前
使用多代理间 AS 诊断系统检测和恢复前缀劫持(2010)
网络·bgp安全
怕什么真理无穷1 小时前
解析OSI 七层模型
网络
斯普信专业组2 小时前
Calico网络架构与实现深度解析(上)
网络·架构
luoganttcc2 小时前
can 协议 600#09000000000000c0 分析
网络