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

相关推荐
麦麦鸡腿堡1 小时前
Java_网络编程_InetAddress类与Socket类
java·服务器·网络
Awkwardx1 小时前
Linux网络编程—应用层协议HTTP
网络·网络协议·http
4***v2141 小时前
详解 为什么 tcp 会出现 粘包 拆包 问题
网络·tcp/ip·php
老前端的功夫2 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
Running_slave3 小时前
你应该了解的TCP滑窗
前端·网络协议·tcp/ip
p66666666684 小时前
vmware虚拟机的三种网络配置详细介绍,包能解决虚拟机网络问题
网络
赖small强5 小时前
【Linux 网络基础】Linux 平台 DHCP 运作原理与握手过程详解
linux·网络·dhcp
无证驾驶梁嗖嗖5 小时前
无需公网 IP,MongoDB 也能跨环境访问?试试这个实用方案
网络协议·tcp/ip·mongodb
Mu.3875 小时前
计算机网络模型
网络·网络协议·计算机网络·安全·http·https