ICMPv4

尽管 IPv4 并非可靠的协议,但它确实会在发生某些错误时发送消息。这些消息使用 Internet 控制消息协议 (ICMPv4) 来发送,其用途是就特定情况下处理 IP 数据包的相关问题提供反馈,而并非是使 IP 可靠。ICMP 消息并非必需的,而且通常出于安全原因而被禁止。

ICMP 是 TCP/IP 协议簇的消息协议。ICMP 提供控制和错误消息,由 ping 和 traceroute 实用程序使用。虽然 ICMP 使用 IP 的基本支持,看起来好象是上层协议 ICMP,但它实际上是 TCP/IP 协议簇中独立的第 3 层协议。
ICMP 消息的类型及其发送原因非常多。我们将介绍其中比较常见的一些消息。
可能发送的 ICMP 消息包括:
  • 主机确认
  • 无法到达目的或服务器
  • 超时
  • 路由重定向
  • 源抑制
主机确认
ICMP 回应消息可用于确定主机是否运行正常。本地主机向一台主机发送 ICMP 回应请求。接收回应消息的主机用 ICMP 应答做出回复,具体过程如图所示。如此使用 ICMP 回应消息是 ping 实用程序的基础。
无法到达目的或服务器
ICMP 目的无法到达消息可用于通知主机无法到达目的或服务。当主机或网关收到无法传送的数据包时,会向发送该数据包的主机发送 ICMP“目的无法到达”数据包,其中包含的代码会说明无法传送该数据包的原因。
“目的无法到达”代码包括:
0 = 网络无法到达
1 = 主机无法到达
2 = 协议无法到达
3 = 端口无法到达
代码网络无法到达 和主机无法到达 是路由器在无法转发数据包时做出的响应。如果路由器没有路由可供接收的数据包使用,则会用代码 = 0 的 ICMP 目的无法到达消息做出响应,表示网络无法到达。如果路由器有连接的路由适用于接收的数据包但却无法将该数据包传送到连接的网络中的主机,该路由器会用代码 = 1 的 ICMP 目的无法到达消息做出响应,表示知道网络但主机无法到达。
终端主机使用代码 2 和 3(协议无法到达 和端口无法到达)来表示无法将包含于数据包中的 TCP 数据段或 UDP 数据报传送到上层服务。
当终端主机接收的数据包中包含要传送到不可用服务的第 4 层 PDU,该主机会用代码 = 2 或代码 = 3 的 ICMP 目的无法到达消息对源主机做出响应,表示服务不可用。服务不可用的原因可能是未运行提供该服务的守护程序或者主机上的安全限制不允许访问该服务。
超时
路由器使用 ICMP 超时消息来表示因数据包的 TTL 字段截止而无法转发该数据包。如果路由器接收数据包并且将该数据包中 TTL 字段的值减为零,则会丢弃该数据包。该路由器可能也会向源主机发送 ICMP 超时消息,通知该主机丢弃数据包的原因。
路由重定向
路由器可使用 ICMP 重定向消息来通知网络中的主机有更佳路由可用于特定目的地址。只有当源主机与两个网关都位于同一个物理网络中时才会使用此消息。路由器收到一个数据包时,如果该数据包有条路由的下一条连接到数据包到达的那个接口,那么该路由器会向源主机发送 ICMP 重定向消息。此消息会将路由表中某个路由所包含的下一跳通知给源主机。
源抑制
ICMP 源抑制消息可用于通知源主机暂时停止发送数据包。如果路由器没有足够的缓冲区空间来接收传入数据包,路由器将丢弃数据包。如果路由器必须这样做,也会向其丢弃的每个报文的源主机发送 ICMP 源抑制消息。
如果数据报抵达速度太快,致使无法处理,目的主机也会发送源抑制消息。
当主机接收 ICMP 源抑制消息时,会向传输层报告此消息。然后,源主机可使用 TCP 流量控制机制来调整传输。

本文出自 “07net01” 博客,请务必保留此出处http://07net01.blog.51cto.com/1192774/571592

一周排行
  • 如果需要在Linux启动时自动加载模块,往往使用mkinitrd命令将模块打包进ramdisk image.仔细研究了rc.sysinit后发现有这样一段代码,可以提供另外一种方式. # Load other use ...
  • 最近由于公司网络总是搞得很慢 大家用得很不爽,于是就萌生一个做个网上监控,和延迟测试的小工具 其实360和金山都有相应的功能 不过嘛,咱码工,用不习惯360的商业气息,金山的不争气   就看看金山的效果图吧   还蛮 ...
  • 2011年10月27日,亚马逊全球运营高级副总裁马克·奥纳托(Marc Onetto)和中国区总裁王汉华,在昆山联合宣布卓越亚马逊改名为亚马逊中国,启用短域名z.cn,并同时宣布亚马逊中国最大的运营中心--昆山运营中 ...
  • 本报记者 闫沁波 重庆报道7月初,西部地区最大的国有担保公司--重庆市三峡担保集团有限公司(下称"三峡担保")发起设立的P2P融资平台"金宝保"正式上线.尽管三峡担保方面不愿公 ...
  • 疾风之刃第二次职业调整 五职业技能调整变动分析 风舞星: 天狼星:                                              时空术士: 剑魔: 血妖姬:         以上就是小编 ...
  • 本文目的在于分析Jetspeed支持集群的现状.首先介绍了集群计算的背景知识,然后使用tomcat作为例子配置了一个集群,接着分析了 jetspeed对集群的支持现状,提出了解决这些问题的办法,最后详细解释了jets ...
  • 众所周知,在电话通讯中,电话用户是靠电话号码来识别的.同样,在网络中为了区别不同的计算机,也需要给计算机指定一个号码,这个号码就是“IP地址”. 什么是IP地址 所谓IP地址就是给每个连接在Internet上的主机分 ...
  • 使用FluorineFx.Net开发的每一个实时通讯功能应用都拥有一个应用程序适配器(ApplicationAdapter),用来管理整个实时通讯应用的生命周期,以及接受和拒绝客户端的连接等.应用程序适配器对象也就相 ...
  • 虽说angular都快出2.0了,到了2.0这些东东都会被干掉.不过我们眼前的事还是要处理. $evalAsync和$timeout到底什么区别,网上说法很多,最近看到的是说在directive里就怎么怎么,在con ...
  • 1 标准库容器 顺序容器:vector.list.deque 容器适配器:stack.queue.priority_queue 2 容器元素类型约束: 容器元素类型必须支持和赋值,因为容器存放的都是元素的副本 容器的 ...