之前两篇《linux常用网络工具:fping主机扫描》和《linux常用网络工具:hping高级主机扫描》都是关于主机扫描的,本篇介绍linux下常用的路由扫描工具traceroute和mtr。
路由扫描主要是查询本机到另一个主机经过的路由跳数及数据延迟情况。
traceroute基本使用
路由扫描工具的原理都是存活时间(ttl)来实现的。每当数据包经过一个路由器,其存活时间就会减1。当其存活时间是0时,主机便取消数据包,并传送一个icmp ttl数据包给原数据包的发出者,路由扫描工具就通过这个回送的icmp来获得经过的每一跳路由的信息。
linux下的traceroute和windows的tracert功能相似,所不同的是windows的tracert发送的是icmp报文,linux的traceroute发送的是udp数据包。
由于traceroute使用udp协议,所以其目标端口号默认为33433,一般应用程序都不会用到这个端口,所以目标主机会回送icmp。
traceroute也支持发送tcp和icmp:
traceroute最简单的基本用法是:traceroute hostname,示例:
traceroute会对每个节点测试三次,因此每一行会有三个时间,通过这个时间可以分析出哪一个路由节点延时最大。
traceroute使用技巧
用traceroute一些网站时,可能无法到达最终节点,如:
这主要是因为有些服务器把udp数据包屏蔽了,所以没有返回icmp。
对于有http服务的主机,可以用参数设置traceroute使用tcp协议进行探测,就可以获得最终节点:
如对本文有疑问, 点击进行留言回复!!
linux下文本编辑器vim的使用方法(复制、粘贴、替换、行号、撤销、多文件操作)
网友评论