找回密码
 立即注册
搜索
查看: 354|回复: 5

ping命令简介

[复制链接]

29

主题

14

回帖

72

积分

注册会员

积分
72
发表于 2006-5-19 22:58:29 | 显示全部楼层 |阅读模式
#1  ping命令简介

我想大多数网虫对ping这个命令一定不陌生吧,
其实,Ping就是一个测试程序,在Win98下的MS-DOS窗口下执行,还有必须连上网(因特网或者局域网),执行格式如下:
  ping [远程服务器名][参数]
  如:ping
http://www.huitianxia.com,运行这个命令将得到http://www.huitianxia.com(汇天下网)的IP地址、传送数据包的最大时间和最小时间等。可以在MS-DOS方式下可键入Ping来查看该命令的参数。,运行这个命令将得到http://www.yesky.com(天极网)的IP地址、传送数据包的最大时间和最小时间等。可以在MS-DOS方式下可键入Ping来查看该命令的参数。它是用于确定本地主机(也就是你的机器)是否能与另一台主机(服务器和像你机器一样的千千万万的机器)成功交换(发送与接收)数据包。再根据返回的信息,你就可以推断TCP/IP参数(因为现在网络一般都是通过TCP/IP协议来传送数据的)是否设置正确,以及运行是否正常、网络是否通畅等,但不是Ping成功就代表TCP/IP配置正确,你有可能要执行大量的本地主机与远程主机的数据包交换,才能确信TCP/IP配置的正确性。
  
  下面就对ping www.yesky.com后屏幕出现的信息逐条进行解释:
  1.Pinging www.yesky.com[210.77.155.200] with 32 bytes of data:
  正在将32字节数据(Windows默认,但可改变)发送到远程服务器www.yesky.com,一旁的数字210.77.155.200就是该服务器的IP地址,所以有时也可用来实现域名与IP地址的转换功能。
  2.Reply from 210.77.155.200:bytes=32 time=126ms ttl=244
  本地主机已收到回送信息,具体为:32字节,共用126毫秒,ttl为244。ttlo (Time to
Live)是存在时间值,你可以通过TTL值推算一下数据包已经通过了多少个路由器:
  源地点TTL起始值(就是比返回TTL略大的一个2的乘方数,如128、256等)- 返回时TTL值。
  例如,返回TTL值为119,那么可以推算数据包离开源地址的TTL起始值为128,而源地点到目标地点要通过9个路由器网段(128-119),如果返回TTL值为244,TTL起始值就是256,源地点到目标地点要通过11个路由器网段。
  3.request timed out
  回收信息时间超时,说明此时网络繁忙,可以稍后再试。
  4.ping statistics for 210.77.155.200:
  Packets:Sent=4,Received=2,lost=2(50%)
  Approximate round trip times in milli-seconds:
  Minimum=177ms,Maximum=182ms,Average=89ms
  对照解释如下:
  Ping 210.77.155.200总的信息如下:
  数据包个数:发送4个数据包(系统缺省设置,每次Ping时向服务器端发送4个数据包),共回收到2个,共丢失2个占总的50%。
  发送时间总的概括:
  最快回收时间为:177毫秒,最慢回收时间为182毫秒,平均为89毫秒。
   常用Ping命令参数选项:
   ping IP -t连续对IP地址执行Ping命令,考虑到被用户以Ctrl+C中断。
   ping IP -L 2000 指定Ping命令中的数据长度为2000字节,而不是缺省的32字节。
   ping IP -n 执行特定次数的Ping命令。}

29

主题

14

回帖

72

积分

注册会员

积分
72
 楼主| 发表于 2006-5-19 23:00:55 | 显示全部楼层
#2  总结: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这几个路由。
回复

使用道具 举报

29

主题

14

回帖

72

积分

注册会员

积分
72
 楼主| 发表于 2006-5-19 23:02:15 | 显示全部楼层
#3  总结: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这几个路由。
回复

使用道具 举报

14

主题

1151

回帖

1528

积分

金牌会员

积分
1528
发表于 2006-5-25 10:45:14 | 显示全部楼层
好详细啊
回复

使用道具 举报

37

主题

425

回帖

612

积分

高级会员

积分
612
发表于 2006-5-25 14:44:55 | 显示全部楼层
只有学过才会了解到啊
回复

使用道具 举报

6

主题

301

回帖

404

积分

中级会员

积分
404
发表于 2006-5-31 15:51:41 | 显示全部楼层
很详尽,谢谢了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|海浩社区

GMT+8, 2025-9-17 04:32 , Processed in 0.079067 second(s), 19 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表