需要帮助解决Unix中的traceroute问题

时间:2011-02-03 15:51:22

标签: python 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 个答案:

答案 0 :(得分:2)

traceroute / tracert在Linux和Windows上的行为方式不同。

Linux将发送一个TTL递减的UDP数据包并侦听ICMP响应。 Windows发送ICMP回应请求并侦听ICMP响应。

Python版本失败,因为UDP数据包被阻止。

  

在类Unix操作系统上,默认情况下traceroute实用程序使用目标端口号为33434到33534的用户数据报协议(UDP)数据报.traceroute实用程序通常有一个选项来指定使用ICMP echo请求(类型8)相反,正如Windows tracert实用程序所使用的那样。

http://en.wikipedia.org/wiki/Traceroute