每天一个Linux命令(49)traceroute命令
traceroute指令让你追踪网络数据包的路由途径,预设数据包大小是40Bytes。
(1)用法:
用法: traceroute [参数] [主机]
(2)功能:
功能: 通过traceroute可以知道信息从计算机到互联网另一端的主机是走的什么路径。当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一样,但基本上来说大部分时候所走的路由是相同的。
traceroute通过发送小的数据包到目的设备直到其返回,来测量其需要多长时间。一条路径上的每个设备traceroute要测3次。输出结果中包括每次测试的时间(ms)和设备的名称(如有的话)及其ip地址。
(3)选项参数:
1) -m 设置检测数据包的最大存活数值TTL的大小。
2) -n 直接使用IP地址而非主机名称。
3) -w<超时秒数> 设置等待远端主机回报的时间
4) -r 忽略普通的Routing Table,直接将数据包送到远端主机上。
5) -q 设置发送探测包的个数
(4)实例:
1)[root@localhost sunjimeng]# traceroute www.baidu.com 查询到百度的站点经过的路径
[root@localhost sunjimeng]# traceroute www.baidu.com
traceroute to www.baidu.com (14.215.177.37), hops max, byte packets
192.168.142.2 (192.168.142.2) 0.116 ms 0.071 ms 0.132 ms
* * *
* * *
* * *
* * *
......
* * *
注意:
有时我们traceroute一台主机时,会看到有一些行是以星号表示的。出现这样的情况,可能是防火墙封掉了ICMP的返回信息,所以我们得不到什么相关的数据包返回数据。
2)[root@localhost sunjimeng]# traceroute -q 4 www.baidu.com 把探测包的个数设置为值4(默认是三次)
[root@localhost sunjimeng]# traceroute -q www.baidu.com
traceroute to www.baidu.com (14.215.177.38), hops max, byte packets
192.168.142.2 (192.168.142.2) 0.114 ms 0.143 ms 0.103 ms 0.135 ms
* * * *
* * * *
* * * *
* * * *
......
* * * *
3)[root@localhost sunjimeng]# traceroute -n www.baidu.com 显示IP地址,不查主机名
[root@localhost sunjimeng]# traceroute -n www.baidu.com
traceroute to www.baidu.com (14.215.177.38), hops max, byte packets
192.168.142.2 0.151 ms 0.107 ms 0.060 ms
* * *
* * *
* * *
* * *
......
* * *
注意:
有时我们在某一网关处延时比较长,有可能是某台网关比较阻塞,也可能是物理设备本身的原因。当然如果某台DNS出现问题时,不能解析主机名、域名时,也会 有延时长的现象;您可以加-n参数来避免DNS解析,以IP格式输出数据。
4)[root@localhost sunjimeng]# traceroute -m 5 www.baidu.com 设置跳数
[root@localhost sunjimeng]# traceroute -m www.baidu.com
traceroute to www.baidu.com (14.215.177.38), hops max, byte packets
192.168.142.2 (192.168.142.2) 0.100 ms 0.130 ms 0.052 ms
* * *
* * *
* * *
* * *
[root@localhost sunjimeng]#
5)[root@localhost sunjimeng]# traceroute -r www.baidu.com 绕过正常的路由表,直接发送到与当前主机相连的IP地址
[root@localhost sunjimeng]# traceroute -r www.baidu.com
traceroute to www.baidu.com (14.215.177.38), hops max, byte packets
connect: 网络不可达
[root@localhost sunjimeng]# traceroute -r 0.0.0.0
traceroute to 0.0.0.0 (0.0.0.0), hops max, byte packets
localhost (127.0.0.1) 0.104 ms 0.012 ms 0.009 ms
(5)其他:
traceroute的工作原理:
Traceroute程序的设计是利用ICMP及IP header的TTL(Time To Live)栏位(field):
首先,traceroute送出一个TTL是1的IP datagram(其实,每次送出的为3个40字节的包,包括源地址,目的地址和包发出的时间标签)到目的地。当路径上的第一个路由器(router)收到这个datagram时,它将TTL减1。此时,TTL变为0了,所以该路由器会将此datagram丢掉,并送回一个「ICMP time exceeded」消息(包括发IP包的源地址,IP包的所有内容及路由器的IP地址),traceroute 收到这个消息后,便知道这个路由器存在于这个路径上,接着traceroute 再送出另一个TTL是2 的datagram,发现第2 个路由器......
traceroute 每次将送出的datagram的TTL 加1来发现另一个路由器,这个重复的动作一直持续到某个datagram 抵达目的地。当datagram到达目的地后,该主机并不会送回ICMP time exceeded消息,因为它已是目的地了,那么traceroute如何得知目的地到达了呢? Traceroute在送出UDP datagrams到目的地时,它所选择送达的port number 是一个一般应用程序都不会用的号码(30000 以上),所以当此UDP datagram 到达目的地后该主机会送回一个「ICMP port unreachable」的消息,而当traceroute 收到这个消息时,便知道目的地已经到达了。所以traceroute 在Server端也是没有所谓的Daemon 程式。
Traceroute提取发 ICMP TTL到期消息设备的IP地址并作域名解析。每次 ,Traceroute都打印出一系列数据,包括所经过的路由设备的域名及 IP地址,三个包每次来回所花时间。
windows下的tracert:
在大多数情况下,我们会在linux主机系统下,直接执行命令行: traceroute hostname。
而在Windows系统下是执行tracert的命令: tracert hostname。
最新文章
- python之路:Day02 --- Python基础2
- keep the bar green to keep the code clean——Junit详解(二)
- Linux守护进程
- Atitit.git的存储结构and 追踪
- mysql metadata lock(二)
- ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)
- MySQL Server类型之MySQL客户端工具的下载、安装和使用
- php float 转int
- 小猪猪逆袭成博士之C++基础篇(三)字符串
- 浅谈linux读写同步机制RCU
- logstash安装配置
- 免费下载获取Odoo中文开发 指南 手册
- angular反向代理配置
- UITransitionView and UILayoutContainerView
- 3.sql2008查询
- php-fpm 的 pm.start_servers 参数调整
- Feed back TFS 2017 RC upgrade status to product team in product group 2017.03.01
- 解析:SO_REUSEADDR bind: address in use
- mysql按时间查询(年/月/日)
- Docker构建ssh镜像
热门文章
- linux内核常用函数或宏
- mysql日期函数 和sql语句扩展information_schema show processlist;
- python 爬虫3 异常处理
- poj 2226(最小覆盖)
- Uncaught Error: artDialog: Document types require more than xhtml1.0
- 【Unity】基于MVC模式的背包系统 UGUI实现
- gcc 编译 连接 生成可执行文件
- 【BZOJ2882】工艺 后缀自动机
- 关于js的当前日期的格式化,和两个日期之间的相减的天数
- java内部类详细介绍