掌握Ping命令技巧 解决网络故障

Advertisement

掌握Ping命令技巧 解决网络故障(1)

作者: 出处:网管员世界  ( 0 ) 砖 ( 2 ) 好 评论 ( 1 ) 条  进入论坛

更新时间:2007-09-03 16:35
关 键 词:Ping 网段
阅读提示:“Ping”命令是我们在判断网络故障常用的命令,但您真正明白这个命令运行后会发生什么,以及出现的各种信息说明了什么吗?其实熟练的掌握Ping命令的各种技巧可以帮助你解决很多网络故障。下面我们就来详细的了解一下Ping命令。

“Ping”命令是我们在判断网络故障常用的命令,但您真正明白这个命令运行后会发生什么,以及出现的各种信息说明了什么吗?其实熟练的掌握Ping命令的各种技巧可以帮助你解决很多网络故障。下面我们就来详细的了解一下Ping命令。

“Ping”的幕后过程

我们以下面一个网络为例:有A、B、C、D四台机子,一台路由RA,子网掩码均为255.255.255.0,默认路由为192.168.0.1

1.在同一网段内

在主机A上运行“Ping 192.168.0.5”后,都发生了些什么呢? 首先,Ping命令会构建一个固定格式的ICMP请求数据包,然后由ICMP协议将这个数据包连同地址“192.168.0.5”一起交给IP层协议(和ICMP一样,实际上是一组后台运行的进程),IP层协议将以地址“192.168.0.5”作为目的地址,本机IP地址作为源地址,加上一些其他的控制信息,构建一个IP数据包,并想办法得到192.168.0.5的MAC地址(物理地址,这是数据链路层协议构建数据链路层的传输单元——帧所必需的),以便交给数据链路层构建一个数据帧。关键就在这里,IP层协议通过机器B的IP地址和自己的子网掩码,发现它跟自己属同一网络,就直接在本网络内查找这台机器的MAC,如果以前两机有过通信,在A机的ARP缓存表应该有B机IP与其MAC的映射关系,如果没有,就发一个ARP请求广播,得到B机的MAC,一并交给数据链路层。后者构建一个数据帧,目的地址是IP层传过来的物理地址,源地址则是本机的物理地址,还要附加上一些控制信息,依据以太网的介质访问规则,将它们传送出去。

主机B收到这个数据帧后,先检查它的目的地址,并和本机的物理地址对比,如符合,则接收;否则丢弃。接收后检查该数据帧,将IP数据包从帧中提取出来,交给本机的IP层协议。同样,IP层检查后,将有用的信息提取后交给ICMP协议,后者处理后,马上构建一个ICMP应答包,发送给主机A,其过程和主机A发送ICMP请求包到主机B一模一样。

2.不在同一网段内

在主机A上运行“Ping 192.168.1.4”后,开始跟上面一样,到了怎样得到MAC地址时,IP协议通过计算发现D机与自己不在同一网段内,就直接将交由路由处理,也就是将路由的MAC取过来,至于怎样得到路由的MAC,跟上面一样,先在ARP缓存表找,找不到就广播吧。路由得到这个数据帧后,再跟主机D进行联系,如果找不到,就向主机A返回一个超时的信息。

对Ping后返回信息的分析

1.Request timed out

这是大家经常碰到的提示信息,很多文章中说这是对方机器置了过滤ICMP数据包,从上面工作过程来看,这是不完全正确的,至少有下几种情况。

498)this.style.width=498;">
图:对Ping后返回信息的分析

(1) 对方已关机,或者网络上根本没有这个地址:比如在上图中主机A中PING 192.168.0.7 ,或者主机B关机了,在主机A中PING 192.168.0.5 都会得到超时的信息。

(2)对方与自己不在同一网段内,通过路由也无法找到对方,但有时对方确实是存在的,当然不存在也是返回超时的信息。

(3)对方确实存在,但设置了ICMP数据包过滤(比如防火墙设置)。

怎样知道对方是存在,还是不存在呢,可以用带参数 -a 的Ping命令探测对方,如果能得到对方的NETBIOS名称,则说明对方是存在的,是有防火墙设置,如果得不到,多半是对方不存在或关机,或不在同一网段内。

(4)错误设置IP地址

正常情况下,一台主机应该有一个网卡,一个IP地址,或多个网卡,多个IP地址(这些地址一定要处于不同的IP子网)。但如果一台电脑的“拨号网络适配器”(相当于一块软网卡)的TCP/IP设置中,设置了一个与网卡IP地址处于同一子网的IP地址,这样,在IP层协议看来,这台主机就有两个不同的接口处于同一网段内。当从这台主机Ping其他的机器时,会存在这样的问题:

A.主机不知道将数据包发到哪个网络接口,因为有两个网络接口都连接在同一网段。

B.主机不知道用哪个地址作为数据包的源地址。因此,从这台主机去Ping其他机器,IP层协议会无法处理,超时后,Ping 就会给出一个“超时无应答”的错误信息提示。但从其他主机Ping这台主机时,请求包从特定的网卡来,ICMP只须简单地将目的、源地址互换,并更改一些标志即可,ICMP应答包能顺利发出,其他主机也就能成功Ping通这台机器了。

2.Destination host Unreachable

(1) 对方与自己不在同一网段内,而自己又未设置默认的路由,比如上例中A机中不设定默认的路由,运行Ping 192.168.0.1.4就会出现“Destination host Unreachable”。

(2)网线出了故障

这里要说明一下“destination host unreachable”和 “time out”的区别,如果所经过的路由器的路由表中具有到达目标的路由,而目标因为其他原因不可到达,这时候会出现“time out”,如果路由表中连到达目标的路由都没有,那就会出现“destination host unreachable”。

3.Bad IP address

这个信息表示您可能没有连接到DNS服务器,所以无法解析这个IP地址,也可能是IP地址不存在。

4.Source quench received

这个信息比较特殊,它出现的机率很少。它表示对方或中途的服务器繁忙无法回应。

5.Unknown host——不知名主机

这种出错信息的意思是,该远程主机的名字不能被域名服务器(DNS)转换成IP地址。故障原因可能是域名服务器有故障,或者其名字不正确,或者网络管理员的系统与远程主机之间的通信线路有故障。

6.No answer——无响应

这种故障说明本地系统有一条通向中心主机的路由,但却接收不到它发给该中心主机的任何信息。故障原因可能是下列之一:中心主机没有工作;本地或中心主机网络配置不正确;本地或中心的路由器没有工作;通信线路有故障;中心主机存在路由选择问题。

7.Ping 127.0.0.1:127.0.0.1是本地循环地址

如果本地址无法Ping通,则表明本地机TCP/IP协议不能正常工作。

8.no rout to host:网卡工作不正常

9.transmit failed,error code:10043网卡驱动不正常

10.unknown host name:DNS配置不正确

以上是我在“拼”(Ping)的过程中,得到一些经验技巧,希望能对大家的工作和学习有所帮助。

Similar Posts:

  • Ping命令迅速处理网络故障的方法

    Ping命令迅速处理网络故障的方法 (1)ping localhost localhost是个作系统的网络保留名,它是127.0.0.1的别名,每台计算机都应该能够将该名字转换成该地址.如果没有做到这,则表示主机文件(/Windows/host)中存在问题. (2)ping 外网地址(如www.zeisp.com) 对这个域名执行Ping www.zeisp.com地址,通常是通过DNS 服务器 如果这里出现故障,则表示DNS服务器的IP地址配置不正确或DNS服务器有故障(对于拨号上网用户,某些

  • 通过查看路由器的端口状态解决网络故障

    大家做网络工程可能会经常遇到种种关于器的问题,但是通常路由器除了看配置外,更常用的办法是通过路由器端口状态看网络故障.下面是笔者的一些经验总结,希望对大家有用. 看路由器的状态,最主要的是看路由器的serial状态和portocol状态.当我们在路由器的特权模式下#show interface interface-number后,出现如下状态: 1.Serial interface-number is down,line protocol is down 可能出现的问题:路由器未加电:LINE未

  • 长ping 命令,检测网络连接状态

    本来想想使用wireShark 抓包工具,检查本机和某服务器之间的网络状态,但wireshark 运行抓取信息太多,所以工作中可以使用下面的简单方法: ping xxx.xxx.xxx.xxx -t >>D:\log.txt 可以将它保存为xx.bat 文件. 它会长ping xxx.xxx.xxx.xxx IP,然后将信息写入到 D:\log.txt 文件.

  • [一文一命令]ping命令详解

    ping 功能简述:Linux系统的ping命令是常用的网络命令,它通常用来测试与目标主机的连通性,我们经常会说"ping一下某机器,看是不是开着".不能打开网页时会说"你先ping网关地址192.168.1.1试试".它通过发送ICMP ECHO_REQUEST数据包到网络主机(send ICMP ECHO_REQUEST tonetwork hosts),并显示响应情况,这样我们就可以根据它输出的信息来确定目标主机是否可访问(但这不是绝对的).有些服务器为了防止

  • 网络故障排错

    在解决网络故障之前,需要了解整个网络的拓扑,要知道网络中有那些设备,这些设备之间是怎样连接的.如果是局域网内的设备,需要知道各个设备的IP地址.子网掩码,如果是广域网设备或者是连接到Internet,需要了解的IP地址.子网掩码.网关地址.DNS地址以及路由表信息.最后的情况是有一张详细的网络图,根据拓扑图分析. 你应该像熟悉从单位回家的路一样,熟悉网络中的设备以及网络拓扑情况.如果你详细了解每条回家的路,在某些情况下,例如下雨的时候,根据以前的经验,如果雨下的大,从地道桥经过的路,可能会由于雨

  • 网卡驱动不当 引发蹊跷网络故障(2)

    从上面的故障排除过程来看,解决网络故障的时候,应该对故障现象进行多角度.全方位的观察,并进行串联式分析.思考,同时付诸于反复式的实践.验证,只有这样才干找到准确的故障原因,并能彻底地解决故障现象.如果单从某一个角度出发观察.思考问题,那么我很容易被故障现象所蒙蔽,那么作出的故障判断自然也就不准确了 局域网运行过程中,客户端系统往往会发生各式各样奇怪的故障现象,如何快速.有效地排除这些客户端系统故障,一直是这些网络管理员必需认真面对的课题 " 事实上,只要在平时善于对各类常见网络故障的发生原因.排

  • 高效排除Linux网络故障—ntop应用实例分析

    From: <网管员世界>杂志 电子工业出版社易飞思公司 摘要:<网管员必读--故障排除>收集了<网管员世界>自创刊以来"故障诊断"栏目中的经典故障诊断案例.第四章讲的是Linux故障诊断,本节说的是高效排除Linux网络故障-ntop应用实例分析. 标签:网络 故障 IE浏览器 Linux ntop 网页 网管员必读--故障排除 4.1.4.7 高效排除Linux网络故障-ntop应用实例分析 曹元其 随着Linux的应用日益广泛,有大量的网络服务

  • Ping 命令详解

    当你的网络出现故障或无法连通时,如何才能简单高效的找出故障?其实只需要一个ping命令,就可以判断故障-- 1.Ping 127.0.0.1: Ping 127.0.0.1是本地回环测试(127开头都是回环地址),它和网卡无关,如果127.0.0.1无法Ping通,则表明本地机TCP/IP协议不能正常工作. 注意:127.0.0.1相当于你机器上的一个虚借口,是回路地址,也就是个逻辑上的INTERFACE,任何时候都是up的,能ping通的话说明你的TCP/IP是否加载成功. 2.Ping本机的

  • 黑客常用 命令8(PING命令)

    讲述它的简单用法: ping这个命令是在windows98/me的dos和winnt/2000的命令行下的 一个命令.它给另一个系统发送一些列的数据包,该系统本身又发回 一个响应,ping命令用于查看网络上的主机是否在工作,它向该主机发送ICMP ECHO_REQUEST包.有时我们 想从网络上的某台主机上下载文件,可是又不知道那台主机是否开着,就需要使用ping命令查看.它返回的结果 如下 Pinging TBid.mshome.net [127.0.0.1] with 32 bytes of

  • UBUNTU下使用ifconfig和route命令手动配置网络

    UBUNTU下使用ifconfig和route命令手动配置网络 LINUX下的网络配置命令是ifconfig类似于WINDOWS命令行中的ipconfig.可以使用ifconfig命令来配置并查看网络接口的配置情况. 例如: (1) 配置eth0的IP地址, 同时激活该设备. #ifconfig eth0 192.168.1.10 netmask 255.255.255.0 up (2) 配置eth0别名设备eth0:1的IP地址,并添加路由. #ifconfig eth0 192.168.1.

Tags: