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

相关推荐
mounter6251 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
ACP广源盛139246256733 小时前
破局 Type‑C 切换器痛点@ACP#GSV6155+LH3828/GSV2221+LH3828 黄金方案
c语言·开发语言·网络·人工智能·嵌入式硬件·计算机外设·电脑
嵌入式小企鹅4 小时前
蓝牙学习系列(八):BLE L2CAP 协议详解
网络·学习·蓝牙·ble·协议栈·l2cap
广州灵眸科技有限公司5 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法
byoass6 小时前
csdn_upload_005
网络·安全·云计算
IT WorryFree6 小时前
飞塔防火墙与第三方设备进行IPSEC故障诊断期间,用户可能会观察到以下错误:
linux·服务器·网络
不是书本的小明8 小时前
K8S应用优化方向
网络·容器·kubernetes
~plus~9 小时前
.NET 8 C# 委托与事件实战教程
网络·c#·.net·.net 8·委托与事件·c#进阶
w6100104669 小时前
CKA-2026-Service
linux·服务器·网络·service·cka
GTgiantech10 小时前
灵活拓展网络边界:电口光模块的智慧选型与部署指南
网络