当前位置: 首页 > news >正文

网络工程师 (45)网际控制报文协议ICMP

前言

       网际控制报文协议ICMP(Internet Control Message Protocol)是TCP/IP协议簇的一个子协议,主要用于在IP主机、路由器之间传递控制消息。

一、定义与功能

       ICMP是TCP/IP模型中网络层的重要成员,与IP协议、ARP协议、RARP协议及IGMP协议共同构成TCP/IP模型中的网络层。ICMP协议是一种面向无连接的协议,用于传输出错报告控制信息。这些控制消息虽然并不传输用户数据,但是对于用户数据的传递起着重要的作用。

       ICMP的主要功能包括:

  1. 侦测远端主机是否存在。
  2. 建立及维护路由资料。
  3. 重导资料传送路径(ICMP重定向)。
  4. 资料流量控制。
  5. 报告错误情况,如目标不可到达、源抑制、超时等。

二、报文格式与类型

       ICMP报文包含在IP数据报中,属于IP的一个用户。一个ICMP报文包括IP头部、ICMP头部和ICMP报文数据部分。IP头部就在ICMP报文的前面,IP头部的Protocol值为1就说明这是一个ICMP报文。

       ICMP头部中的类型(Type)域用于说明ICMP报文的作用及格式,此外还有一个代码(Code)域用于详细说明某种ICMP报文的类型。ICMP报文种类主要分为三大类:ICMP差错报文、ICMP控制报文和ICMP请求/应答报文。

       已经定义的ICMP消息类型大约有十多种,每种ICMP数据类型都被封装在一个IP数据包中。主要的ICMP消息类型包括:

  1. 响应请求与应答报文:日常使用最多的ping,就是响应请求(Type=8)和应答(Type=0)。一台主机向一个节点发送一个Type=8的ICMP报文,如果途中没有异常(例如被路由器丢弃、目标不回应ICMP或传输失败),则目标返回Type=0的ICMP报文,说明这台主机存在。
  2. 目标不可到达报文:目标不可到达报文(Type=3)在路由器或主机不能传递数据报时使用。例如要连接对方一个不存在的系统端口(端口号小于1024)时,将返回Type=3、Code=3的ICMP报文。常见的不可到达类型还有网络不可到达(Code=0)、主机不可到达(Code=1)、协议不可到达(Code=2)等。
  3. 源抑制报文:充当一个控制流量的角色,通知主机减少数据报流量。由于ICMP没有恢复传输的报文,所以只要停止该报文,主机就会逐渐恢复传输速率。
  4. 超时报文:无连接方式网络的问题就是数据报会丢失,或者长时间在网络游荡而找不到目标,或者拥塞导致主机在规定时间内无法重组数据报分段,这时就要触发ICMP超时报文的产生。超时报文的代码域有两种取值:Code=0表示传输超时,Code=1表示重组分段超时。
  5. 时间戳请求与应答报文:时间戳请求报文(Type=13)和时间戳应答报文(Type=14)用于测试两台主机之间数据报来回一次的传输时间。传输时,主机填充原始时间戳,接收方收到请求后填充接收时间戳后以Type=14的报文格式返回,发送方计算这个时间差。

三、应用

  1. 网络连通性测试:通过ping命令发送ICMP回送请求报文,测试目标主机是否可达。如果目标主机能够返回ICMP回送应答报文,则说明网络连通性正常。
  2. 路由跟踪:通过tracert(Windows)或traceroute(UNIX/Linux)命令发送一系列IP数据报,数据报中封装的是无法交付的UDP用户数据报。每个数据报的TTL值从1开始递增,当数据报到达路径上的路由器时,路由器会将其TTL值减1并检查是否为零。如果TTL值为零,则路由器会丢弃该数据报并向源主机发送ICMP时间超过差错报告报文。源主机根据收到的ICMP报文可以确定数据包到达目的主机所经过的路径以及每个路径的往返时间。
  3. MTU测试:通过发送不同大小的ICMP数据包来测试网络路径上的最大传输单元(MTU)。这有助于确定数据包在传输过程中是否需要分片以及分片的大小。

四、安全性

       虽然ICMP在网络管理中扮演着重要的角色,但它也存在一些安全性问题。例如,ICMP攻击者可以利用ICMP报文进行网络扫描、DDoS攻击等。因此,在网络配置中需要合理设置ICMP报文的过滤规则,以防范潜在的安全威胁。

 结语    

永远自在

清澈明朗

!!!

相关文章:

  • blackbox.ai 一站式AI代理 畅享顶级模型
  • 如何使用 vxe-table grid 全配置式给单元格字段格式化内容,格式化下拉选项内容
  • MybatisPlus-扩展功能
  • Axure RP11 新功能:为设计师插上“翅膀”
  • Low code web framework for real world applications, in Python and Javascript
  • 基于SpringBoot+Vue的老年人体检管理系统的设计与实现(源码+SQL脚本+LW+部署讲解等)
  • Android JNI的理解与使用。
  • 获取某厂招聘岗位信息
  • linux 面试题
  • 后台管理系统-项目初始化
  • 网络编程(24)——实现带参数的http-get请求
  • Linux 文件内容查看
  • 力扣LeetCode: 740 删除并获得点数
  • 机器视觉--图像的运算(乘法)
  • EXCEL解决IF函数“您已为此函数输入太多个参数”的报错
  • 12. Docker 网络(bridge,host,none,container,自定义网络)配置操作详解
  • 通读【基于深度学习的网络异常流量检测研究与系统实现】
  • Django 5实用指南(二)项目结构与管理
  • 【R语言】主成分分析与因子分析
  • 【vue】nodejs版本管理利器:nvm
  • 习近平同欧洲理事会主席科斯塔、欧盟委员会主席冯德莱恩就中欧建交50周年互致贺电
  • 创历史同期新高!“五一”假期全国快递揽投超48亿件
  • 台湾花莲县海域发生5.7级地震,震源深度15公里
  • 巴基斯坦宣布禁止与印度的进口贸易
  • 莫斯科一机场实施临时限制措施
  • 国铁集团:5月4日全国铁路预计发送旅客2040万人次