ICMP协议及Wireshark分析

一、ICMP协议

为了更有效地转发IP数据报和提高交付成功的机会,在网际层使用了ICMP(Internet Control Message Protocol),网际控制报文协议。ICMP报文装在IP数据报中,属于IP层的协议。ICMP报文作为IP层的数据报的数据,加上数据报的首部,组成IP数据报发送出去。
在这里插入图片描述
ICMP报文的种类分为两种:ICMP差错报告报文和ICMP询问报文。

ICMP报文种类类型的值ICMP报文的类型
差错报告报文3终点不可达
差错报告报文11时间超过
差错报告报文12参数问题
差错报告报文5改变路由(Redirect)
询问报文8或0回送(Echo)请求或回答
询问报文13或14时间戳(Timestamp)请求或回答

所有的ICMP差错报告报文中的数据字段都具有相同的格式。把收到的需要进行差错报告的IP数据报的首部和IP数据报数据字段的前8个字节(为了得到运输层的端口号及报文的发送序号)提取出来,作为ICMP报文结构的数据字段。再加上相应的ICMP差错报告报文的前8个字节,就构成了ICMP差错报告报文。
在这里插入图片描述

二、利用Wireshark分析ICMP数据包

通过ping测试主机(192.168.43.83)与同网段其他主机(192.168.43.1)的连通性,利用Wireshark捕获并分析此过程中的数据包。此过程中出现了三种类型的ICMP报文,分别是:询问报文中的回送请求和回答、差错报告报文中的时间超过、差错报告报文中的终点不可达。
在这里插入图片描述

1.询问报文:回送请求或回答

ICMP回送请求报文是由主机或路由器向一个特定的目的主机发出来的询问。收到此报文的主机必须给源主机或路由器发送ICMP回送回答报文。这种询问报文用来测试目的站是否可以到达以及了解相关状态。
请求报文:
在这里插入图片描述
回答报文:
在这里插入图片描述

2.差错报告报文:时间超过

当路由器收到生存时间为0的数据报时,除丢弃该数据报外,还要向源点发送时间超过报文;当终点在预先规定的时间内不能收到一个数据报的全部数据报片时,就把已收到的数据报片都丢弃,并向源点发送时间超过报文。
在这里插入图片描述

3.差错报告报文:终点不可达

当路由器或主机不能交付数据报时,就向源点发送终点不可达报文。
在这里插入图片描述

三、ICMP应用举例:PING和traceroute

1.PING

分组网间探测PING(Packet InterNet Groper),用来测试两台主机之间的连通性。PING使用了ICMP回送请求与回送回答报文。PING是应用层直接使用网络层ICMP的一个例子,它没有通过运输层的TCP或UDP。
在这里插入图片描述
在这里插入图片描述

2.traceroute

traceroute(Windows中的命令是tracert)用来跟踪一个分组从源点到终点的路径。Traceroute从源主机向目的主机发送一连串的IP数据报,数据报中封装的是无法交付的UDP用户数据报。
在这里插入图片描述
在这里插入图片描述

  • 4
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值