文档介绍:ICMP:控制报文协议ICMP报文通常被IP层或更高层协议(TCP或UDP)使用,用于传递差错报文以及其他需要注意的信息。ICMP报文是在IP数据报内部被传输的,如图1所示。【P数据报IP首部1CMF报文图1ICMPJJ装在IP数据报内部ICMP的正式规范参见RFC792。ICMP报文格式如图2所示。次世字段可以有15个不同的值,以描述特定类型的ICMP报文。某些ICMP报文还使用代码字段的值进一步描述不同的条件。校验和字段计算覆盖整个ICMP报文。0 78 1516 318bil类羽8bii代码16bil校验和(不同类型和代码有不同的内容)图2ICMP报文格式ICMP报文的各种类型如图3所示,不同类型由报文中的类型字段和代码字段共同决定。当发送一份ICMP差错报文时,报文始终包含IP首部和产生ICMP差错报文的IP数据报中数据部分的前8个字节。这样,接收ICMP差错报文的模块就会把它与某个特定的I办议(根据IP数据报首部中的I办议字段来判断)和用户进程(根据包含在IP数据报前8个字节中的TCP或UDP报文首部中的TCP或UDP端口号來判断)联系起:來。下面各种情况都不会产生ICMP养错报文:ICMP差错报文(但是,ICMP查询报文可能产生ICMP差错报文);目的地址是广播地址或多播地址(D类地址〉的IP数据报;作为链路层广播的数据报;不是IP分片的第一片;源地址不是单个主机的数据报。也就是说,源地址不能为零地址、环冋地址、广播地址或多播地址。这些规则是为了防止过去允许ICMP差错报文对广播分组响应所带来的广播风暴。ICMP端口不可到达差错ICMP差错报文(如图4所示),即端口不可到达报文,它是ICMP目的不可到达报文中的一种,以此来看一看ICMP差错报文中所附加的信息,使用UDP來査看它。UDP的规则Z—是,如果收到一份UDP数据报而目的端口与某个正在使用的进程不相符,那么UDP返回一个ICMP不可达报文。(BSD系统不把从socket接收到的ICMP报文中的UDP数据通知给用户进程,除非该进程己经发送一个connect命令给该socket。)类型 代码 描述查询差错0 0 回显应答(Ping应答,第7草)■3 目的不可达:0 网络不可达()主机不可达()协议不可达端口不可达($5节)需要进行分片但设置了不分片比特()源站选路失败(8一5节)目的网络不认识目的主机不认识源主机被隔离(作废不用)目的网络被强制禁止目的主机被强制禁止由于服务类型TOS,网络不可达()由于服务类型TOS,主机不可达()由于过滤,通信被强制禁止主机越权优先权中止生效4 0 源端被关闭(基本流控制,)5 重定向():0 对网络重定向对主机重定向对服务类型和网络重定向对服务类型和主机重定向8 0 请求回显(Pmg请求,第7$)•0 路由器通告()0 路由器请求(9•&节)«■11 超时:0 传输期间生存时间为0(Traceroute,第8草)1 在数据报组装期间生存时间为0()■•12 参数问题:0 坏的IP首部(包括各种差错)1 缺少必需的选项••13 0 时间戳请求()1斗 0 时间戳应答($4节)0 信息请求(作废不用)0 信息应答(作废不用)17 0 地址掩码请求(63节)1S 0