每天掌握一个网络协议----ICMP

ICMP(Internet Control Message Protocol)互联网控制消息协议是TCP/IP协议族中的一个重要协议,主要用于IP主机和路由器之间传递控制和错误消息

ICMP是网络层协议,主要用于网络问题诊断,检测网络是否可达并诊断错误原因

常见的pingtraceroute命令都依赖于ICMP协议实现

ICMP的工作原理

ICMP通过在IP数据包中封装控制消息,实现网络诊断和错误报告

ICMP实际上是一个差错报告协议,它不会尝试纠正错误,而是会将数据报文传输过程中遇到的问题报告给源设备

ICMP无法确定源设备到目的设备链路中哪个环节出现问题,但是它能够确定问题原因,通过问题原因协助运维人员定位网络链路中存在的问题

ICMP报文格式

每一个ICMP消息都包含引发这个ICMP消息的完整IP包头,ICMP报文作为IP数据包的数据部分封装在IP报文内部

ICMP报文中包含了三个固定字段,可以通过这三个字段确定链路中的错误类型

  • Type:ICMP消息的类型
  • Code:ICMP消息类型细分子项
  • Checksum:ICMP报文的校验和

ICMP报文格式

ICMP消息类型

|----------|-------|----------|
| ICMP报文类型 | 类型值 | 功能描述 |
| 差错报文 | 3 | 终点不可达 |
| 差错报文 | 5 | 重定向 |
| 差错报文 | 11 | 超时 |
| 差错报文 | 12 | 参数异常 |
| 询问报文 | 8/0 | 回送请求/应答 |
| 询问报文 | 13/14 | 时间戳请求/回答 |

ps:根据RFC 6633规定,类型4、10、9、15、16、17、18类型的报文均不再使用

ICMP的应用

PING命令工作原理

Ping是一个网络工具,用于测试网络连接是否可达,如:ping www.baidu.com来测试当前设备是否已经建立网络链接,是我们最常使用的命令之一;

Ping通过发送ICMP回显请求,并等待接收回显来工作

  1. 发送请求:当用户运行ping命令时,工具会创建一个ICMP回显请求数据包,并将其发送到指定的目标IP地址
  2. 接收应答:目标主机收到请求后,解析数据包并生成ICMP回显应答数据报文,返回给源设备
  3. 计算延时:源主机收到ICMP应答之后,计算从报文发送到接收应答所花费的时间,并显示给用户
  4. 统计信息:ping会统计发送和接收的报文数量,计算丢包率

ICMP的安全特性

为了防止ICMP消息的无线产生以及网络风暴,在一些特定场景下,ICMP不会产生差错报文

  • ICMP的差错报文不会再产生差错报文
  • 目的地址是广播地址或多播地址的IP数据报文
  • 不是IP分片的第一片
  • 作为链路层广播的数据包
  • 源地址不是单个主机的数据包,如零地址、环回地址、广播地址和多播地址

ICMP本身非常简单,也没有验证机制,因为它也经常被用于网络攻击

  • ICMP攻击

目前ICMP攻击的绝大部分都可以归类为拒绝服务攻击(Denial of Service,DOS),即ICMP泛洪:攻击者在短时间内发出海量的ICMP报文,使得局域网的网络资源被占满,从而无法为用户提供正常服务

  • 端口扫描攻击(针对连接的DOS攻击)

攻击者发送大量的端口扫描报文,交换机需要回应大量的ICMP目的地址不可达报文,这种攻击即占用了系统的资源,又能向攻击者提供系统当前开放的端口,进而针对端口展开更具针对性的攻击

ICMP攻击的防范方法

ICMP的防范可从减轻设备处理压力入手,目前主要可以通过ICMP报文限速、ICMP报文合法性检查、不响应不可达报文的方式来降低ICMP攻击的效果

  • 报文限速

ICMP报文限速包含了端口限速、VLAN限速和全局限速,同时也实现芯片的限速,通过多个维度避免ICMP泛洪的攻击

  • 合法性检查&丢弃不需要处理的报文

对于不合法的ICMP报文,如TTL为0、ICMP类型为15、16、17的报文,直接丢弃

  • 不响应不可达报文

设备收到不可达报文时,不对其进行响应,从而保护CPU资源

相关推荐
迎仔31 分钟前
B-算力中心网络隔离的必要性:为什么必须隔离?
网络
野指针YZZ1 小时前
一键配置RK3588网络与SSH远程连接
网络·ssh·rk3588
迎仔2 小时前
10-网络安全监控与事件响应:数字世界的智能监控与应急系统
网络·安全·web安全
上海合宙LuatOS2 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
深圳市恒星物联科技有限公司3 小时前
水质流量监测仪:复合指标监测的管网智能感知设备
大数据·网络·人工智能
三水不滴4 小时前
有 HTTP 了为什么还要有 RPC?
经验分享·笔记·网络协议·计算机网络·http·rpc
科技块儿4 小时前
2026年我会推荐哪些IP归属地查询网站?
网络·ip地址·ip归属地·运维工具·网络工具·实用网站·2026工具推荐
米羊1214 小时前
已有安全措施确认(中)
网络
迎仔5 小时前
A-算力中心网络隔离总览:数字世界的“酒店房间“
网络
宝塔面板5 小时前
AllinSSL 一站式搞定 SSL 自动续期:永久免费,开源可自托管
网络·网络协议·ssl