需要帮助解决Unix中的traceroute问题
我有一个用于Unix系统的traceroute Python程序,它可以显示数据包从本地计算机到达目标的路径,也就是数据包经过的路由器顺序。问题是我得到的输出显示:
traceroute to yahoo.co.in (68.180.206.184), 30 hops max, 60 byte packets
1 * * *
2 * * *
3 * * *
4 * * *
5 * * *
6 * * *
7 * * *
8 * * *
9 * * *
.
.
.
30 * * *
我使用的是DSL连接。这个程序在Windows命令行(cmd.exe)上运行得很好。那上面的输出到底是什么原因呢?
代码大概是这样的:
#!/usr/bin/python
import socket
def main(dest_name):
dest_addr = socket.gethostbyname(dest_name)
port = 33434
max_hops = 30
icmp = socket.getprotobyname('icmp')
udp = socket.getprotobyname('udp')
ttl = 1
while True:
recv_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp)
send_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, udp)
send_socket.setsockopt(socket.SOL_IP, socket.IP_TTL, ttl)
recv_socket.bind(("", port))
send_socket.sendto("", (dest_name, port))
curr_addr = None
curr_name = None
try:
_, curr_addr = recv_socket.recvfrom(512)
curr_addr = curr_addr[0]
try:
curr_name = socket.gethostbyaddr(curr_addr)[0]
except socket.error:
curr_name = curr_addr
except socket.error:
pass
finally:
send_socket.close()
recv_socket.close()
if curr_addr is not None:
curr_host = "%s (%s)" % (curr_name, curr_addr)
else:
curr_host = "*"
print "%d\t%s" % (ttl, curr_host)
ttl += 1
if curr_addr == dest_addr or ttl > max_hops:
break
if __name__ == "__main__":
main('yahoo.co.in')**
1 个回答
2
traceroute(跟踪路由)和 tracert 在 Linux 和 Windows 上的表现是不同的。
在 Linux 系统中,它会发送一个带有逐渐减小的生存时间(TTL)的 UDP 数据包,并监听 ICMP 的回应。而在 Windows 系统中,它发送的是 ICMP 回显请求,并同样监听 ICMP 的回应。
Python 版本之所以失败,是因为 UDP 数据包被阻止了。
在类 Unix 操作系统中,traceroute 工具默认使用的是用户数据报协议(UDP),目标端口号范围是 33434 到 33534。traceroute 通常有一个选项,可以选择使用 ICMP 回显请求(类型 8),这也是 Windows 的 tracert 工具所使用的。