网络故障诊断 - 使用TTL分析网络故障

网络 布线接入
通过查看数据包的TTL,可以确定网络传输是否正常。如果捕获到的数据包的TTL值过小,则表示网络中很可能存在传输故障,应及时检查网络中三层设备的路由表配置,以及各主机上的路由表信息。

【51CTO.com 综合报道】一、TTL简介

TTL,全称是Time To Live,中文名为生存时间,它是IP报头中一个非常重要的参数。通过TTL的值,我们可以判断出当前网络IP层的工作状况。

TTL告诉网络中的路由器数据包在网络中的时间是否太长而应被丢弃,TTL的最初设想是确定一个时间范围,超过此时间就把包丢弃。由于数据包每经过一个路由器时,TTL值都会至少被路由器减1,所以TTL值通常表示包在被丢弃前还能最多经过的路由器个数。当TTL值为0时,路由器丢弃该数据包,并发送一个ICMP报文给数据包的最初发送者。

有很多原因会导致数据包在一定时间内不能被传递到目的地。例如,不正确的路由表配置可能导致数据包的无限循环,而解决方法就是在一段时间后丢弃这个数据包,然后给发送者发送一个报文,由发送者决定是否重发该数据包。当网络出现这种情况时,数据包就会在路由表中配置错误的路由器处重复发送,每发送一次,TTL值减1,直到TTL为0时路由器丢弃该数据包,造成网络中数据传输错误。

操作系统和传输协议不同,对应TTL的默认值也不同。表1列出了常见操作系统通过TCP和UDP协议传输时的TTL默认值。

 
表1 不同操作系统的TTL默认值

二、查看数据包的TTL值并分析传输故障

网络中的网络设备,其内部都是由操作系统进行处理的(有些硬件设备将系统预装在了硬件芯片里面),在网络遇到传输故障时,我们可以使用网络检测软件,结合上表的信息对网络中流通的数据包进行检测,查看数据包的TTL值,以确定故障是否由错误的路由等原因引起。图1是使用科来网络分析系统5.0查看一个数据包TTL值的情况。 

 
图1 科来网络分析系统5.0查看到的TTL值

图中的生存时间(TTL)是247,结合表1,确定出这个数据包在从源端(这里是61.139.2.69)到目的端(这里是192.168.10.44)共经历了255-247=8个路由器,且在传输过程中未出现故障。

注意:

1.确定数据包在网络中经历了多少个路由器,可用数据包源端设备的TTL默认值减去捕获到的数据包TTL值;

2.在不知道数据包源端设备的默认TTL时,一般用大于捕获数据包的TTL,且最接近这个TTL的默认值。

3.TTL字段长1个字节,所以TTL的最大值255;

通过查看数据包的TTL,可以确定网络传输是否正常。如果捕获到的数据包的TTL值过小,则表示网络中很可能存在传输故障,应及时检查网络中三层设备的路由表配置,以及各主机上的路由表信息。

责任编辑:许凤丽 来源: 51CTO.com
相关推荐

2013-05-22 17:18:13

2009-11-17 18:44:44

2009-11-24 18:34:23

网络故障诊断路由器

2009-09-11 03:21:00

网络故障诊断

2009-12-23 10:50:51

网络故障诊断

2011-01-24 13:42:27

网络故障网络故障修复

2010-08-16 13:43:40

路由器网络诊断

2010-08-18 08:59:00

路由器网络诊断

2011-09-09 13:42:12

网络故障路由器

2009-12-23 10:37:24

网络故障诊断

2009-09-17 12:55:28

WSUS服务器

2009-11-17 17:45:59

2013-04-07 13:47:12

2011-03-14 14:13:28

网络故障

2010-06-09 16:09:42

TCP IP协议网络故障诊断

2009-06-25 09:58:03

2010-08-26 15:11:19

2010-06-09 16:17:20

TCP IP协议网络故

2009-08-16 16:11:05

2018-08-08 14:39:22

网络故障ping网络协议
点赞
收藏

51CTO技术栈公众号