每天掌握一个网络协议----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资源

相关推荐
科技块儿9 小时前
如何使用IP数据云提升网络风控、减少业务欺诈
网络·网络协议·tcp/ip
fei_sun9 小时前
【计网】2025年真题
网络
Fnetlink19 小时前
中小企业网络环境优化与安全建设
网络·安全·web安全
爬山算法10 小时前
Netty(10)Netty的粘包和拆包问题是什么?如何解决它们?
服务器·网络·tcp/ip
Sleepy MargulisItG10 小时前
【Linux网络编程】应用层协议:HTTP协议
linux·服务器·网络·http
bruce_哈哈哈10 小时前
车载网络--soa总结--some/ip等认识
网络
logic_510 小时前
静态路由配置
运维·服务器·网络
门思科技10 小时前
企业级 LoRaWAN 网关远程运维方案对比:VPN 与 NPS FRP 的技术与安全差异分析
运维·网络·安全
kkk_皮蛋11 小时前
RTCP: 统计、同步与网络自适应
网络
suzhou_speeder11 小时前
企业数字化网络稳定运行与智能化管理解决方案
运维·服务器·网络·交换机·poe·poe交换机