欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

详细讲解Windows下ping命令的使用

程序员文章站 2022-03-09 18:09:26
详细讲解Windows下ping命令的使用...

对于windows下ping命令相信大家已经再熟悉不过了,但是能把ping的功能发挥到最大的人却并不是很多,当然我也并不是说我可以让ping发挥最大的功能,我也只不过经常用ping这个工具,也总结了一些小经验,现在和大家分享一下。

  现在我就参照ping命令的帮助说明来给大家说说我使用ping时会用到的技巧,ping只有在安装了tcp/ip协议以后才可以使用:

  ping [-t] [-a] [-n count] [-l length] [-f] [-i ttl] [-v tos] [-r count] [-s count] [[-j computer-list] | [-k computer-list]] [-w timeout] destination-list
  
  options:
  
  -t ping the specified host until stopped.to see statistics and continue - type control-break;to stop - type control-c.
  
  不停的ping地方主机,直到你按下control-c

此功能没有什么特别的技巧,不过可以配合其他参数使用,将在下面提到。
  
  -a resolve addresses to hostnames.
  
  解析计算机netbios名。
  
  示例:c:\>ping -a 192.168.1.21
  
  pinging iceblood.yofor.com [192.168.1.21] with 32 bytes of data:  
  reply from 192.168.1.21: bytes=32 time<10ms ttl=254  
  reply from 192.168.1.21: bytes=32 time<10ms ttl=254  
  reply from 192.168.1.21: bytes=32 time<10ms ttl=254  
  reply from 192.168.1.21: bytes=32 time<10ms ttl=254
  
  ping statistics for 192.168.1.21:  
  packets: sent = 4, received = 4, lost = 0 (0% loss),approximate round trip times in milli-seconds:
  
  minimum = 0ms, maximum = 0ms, average = 0ms
  
  从上面就可以知道ip为192.168.1.21的计算机netbios名为iceblood.yofor.com。

  -n count number of echo requests to send.
  
  发送count指定的echo数据包数。
  
  在默认情况下,一般都只发送四个数据包,通过这个命令可以自己定义发送的个数,对衡量网络速度很有帮助,比如我想测试发送50个数据包的返回的平均时间为多少,最快时间为多少,最慢时间为多少就可以通过以下获知:
  
  c:\>ping -n 50 202.103.96.68
  
  pinging 202.103.96.68 with 32 bytes of data:  
  reply from 202.103.96.68: bytes=32 time=50ms ttl=241  
  reply from 202.103.96.68: bytes=32 time=50ms ttl=241
  reply from 202.103.96.68: bytes=32 time=50ms ttl=241
  
  request timed out.
  
  ………………
  
  reply from 202.103.96.68: bytes=32 time=50ms ttl=241  
  reply from 202.103.96.68: bytes=32 time=50ms ttl=241
  
  ping statistics for 202.103.96.68:
  
  packets: sent = 50, received = 48, lost = 2 (4% loss),approximate round trip times in milli-seconds:
  
  minimum = 40ms, maximum = 51ms, average = 46ms
  
  从以上我就可以知道在给202.103.96.68发送50个数据包的过程当中,返回了48个,其中有两个由于未知原因丢失,这48个数据包当中返回速度最快为40ms,最慢为51ms,平均速度为46ms。
  
  -l size send buffer size.
  
  定义echo数据包大小。
  
  在默认的情况下windows的ping发送的数据包大小为32byt,我们也可以自己定义它的大小,但有一个大小的限制,就是最大只能发送65500byt,也许有人会问为什么要限制到65500byt,因为windows系列的系统都有一个安全漏洞(也许还包括其他系统)就是当向对方一次发送的数据包大于或等于65532时,对方就很有可能挡机,所以微软公司为了解决这一安全漏洞于是限制了ping的数据包大小。虽然微软公司已经做了此限制,但这个参数配合其他参数以后危害依然非常强大,比如我们就可以通过配合-t参数来实现一个带有攻击性的命令:(以下介绍带有危险性,仅用于试验,请勿轻易施于别人机器上,否则后果自负)
  
  c:\>ping -l 65500 -t 192.168.1.21
  
  pinging 192.168.1.21 with 65500 bytes of data:  
  reply from 192.168.1.21: bytes=65500 time<10ms ttl=254  
  reply from 192.168.1.21: bytes=65500 time<10ms ttl=254
  
  ………………
  
  这样它就会不停的向192.168.1.21计算机发送大小为65500byt的数据包,如果你只有一台计算机也许没有什么效果,但如果有很多计算机那么就可以使对方完全瘫痪,我曾经就做过这样的试验,当我同时使用10台以上计算机ping一台win2000pro系统的计算机时,不到5分钟对方的网络就已经完全瘫痪,网络严重堵塞,http和ftp服务完全停止,由此可见威力非同小可。

  
  -f set don't fragment flag in packet.
  
  在数据包中发送“不要分段”标志。
  
  在一般你所发送的数据包都会通过路由分段再发送给对方,加上此参数以后路由就不会再分段处理。
  
 -i ttl time to live.
  
  指定ttl值在对方的系统里停留的时间。
  
  此参数同样是帮助你检查网络运转情况的。
  
 -v tos type of service.
  
  将“服务类型”字段设置为 tos 指定的值。
  
-r count record route for count hops.
  
  在“记录路由”字段中记录传出和返回数据包的路由。
  
  在一般情况下你发送的数据包是通过一个个路由才到达对方的,但到底是经过了哪些路由呢?通过此参数就可以设定你想探测经过的路由的个数,不过限制在了9个,也就是说你只能跟踪到9个路由,如果想探测更多,可以通过其他命令实现,我将在以后的文章中给大家讲解。以下为示例:
  
  c:\>ping -n 1 -r 9 202.96.105.101 (发送一个数据包,最多记录9个路由)
  
  pinging 202.96.105.101 with 32 bytes of data:
  
  reply from 202.96.105.101: bytes=32 time=10ms ttl=249  
  route: 202.107.208.187 ->  
  202.107.210.214 ->  
  61.153.112.70 ->  
  61.153.112.89 ->  
  202.96.105.149 ->  
  202.96.105.97 ->  
  202.96.105.101 ->  
  202.96.105.150 ->  
  61.153.112.90
  
  ping statistics for 202.96.105.101:
  
  packets: sent = 1, received = 1, lost = 0 (0% loss),  
  approximate round trip times in milli-seconds:  
  minimum = 10ms, maximum = 10ms, average = 10ms  
  从上面我就可以知道从我的计算机到202.96.105.101一共通过了202.107.208.187 ,202.107.210.214 , 61.153.112.70 , 61.153.112.89 , 202.96.105.149 , 202.96.105.97这几个路由。
  
 -s count timestamp for count hops.
  
  指定 count 指定的跃点数的时间戳。
  
  此参数和-r差不多,只是这个参数不记录数据包返回所经过的路由,最多也只记录4个。
  
-j host-list loose source route along host-list.
  
  利用 computer-list 指定的计算机列表路由数据包。连续计算机可以被中间网关分隔(路由稀疏源)ip 允许的最大数量为 9。
  
-k host-list strict source route along host-list.
  
  利用 computer-list 指定的计算机列表路由数据包。连续计算机不能被中间网关分隔(路由严格源)ip 允许的最大数量为 9。
  
-w timeout timeout in milliseconds to wait for each reply.
  
  指定超时间隔,单位为毫秒。
  
  此参数没有什么其他技巧。
  
  ping命令的其他技巧:在一般情况下还可以通过ping对方让对方返回给你的ttl值大小,粗略的判断目标主机的系统类型是windows系列还是unix/linux系列,一般情况下windows系列的系统返回的ttl值在100-130之间,而unix/linux系列的系统返回的ttl值在240-255之间,当然ttl的值在对方的主机里是可以修改的,windows系列的系统可以通过修改注册表以下键值实现:
  
  [hkey_local_machine\system\currentcontrolset\services\tcpip\parameters]
  
  "defaultttl"=dword:000000ff  
  255---ff  
  128---80  
  64----40  
  32----20
  
 

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数据包,从以上我们介绍的工作流程来看,这种说法不完全正确,可能有以下几种情况:
  (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命令也基本上完全讲解完了,其中还有-j,-k参数我还没有详细说明,由于某些原因也包括我自己所收集的资料过少这里也没有向大家详细介绍,请大家见谅,如果在看了这篇文章的朋友当中有知道得比我更多的,以及其他使用技巧的也希望您能告诉我,并在此先谢过!

相关标签: Ping