请教一个计算机网络的问题,为什么 traceroute 看不到路由信息 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
rrubick
V2EX    计算机

请教一个计算机网络的问题,为什么 traceroute 看不到路由信息

  •  
  •   rrubick 2021-08-05 18:38:22 +08:00 2366 次点击
    这是一个创建于 1596 天前的主题,其中的信息可能已经有所发展或是发生改变。

    起因

    公司里,A 电脑使用有线连接,本机使用 wifi 连接。本机 ping A 电脑能 ping 通,但是 traceroute 找不到路由信息

    相关截图

    2

    疑问

    想请问各位大佬:

    为什么 traceroute 返回都是 * 并且看不到路由信息(如果能详细就最好了,我学习以后再来加深理解)

    感觉计算机网络还得再学一学。。。

    第 1 条附言    2021-08-05 19:26:26 +08:00
     ~ traceroute -P TCP 172.16.107.38 traceroute to 172.16.107.38 (172.16.107.38), 64 hops max, 64 byte packets 1 * * * 2 * * * 3 * * * 4 * * * 5 * * * 6 *^Z [10] + 787 suspended traceroute -P TCP 172.16.107.38 ~ traceroute -P UDP 172.16.107.38 traceroute to 172.16.107.38 (172.16.107.38), 64 hops max, 52 byte packets 1 * * * 2 172.16.107.38 (172.16.107.38) 25.092 ms 18.907 ms 5.527 ms ~ traceroute -P ICMP 172.16.107.38 traceroute to 172.16.107.38 (172.16.107.38), 64 hops max, 72 byte packets 1 * * * 2 172.16.107.38 (172.16.107.38) 9.580 ms 4.589 ms 5.172 ms 
    第 2 条附言    2021-08-06 10:29:30 +08:00
     My traceroute [v0.94] MacBook-Pro.local (172.16.101.60) -> 172.16.107.38 2021-08-06T10:28:13+0800 Keys: Help Display mode Restart statistics Order of fields quit Packets Pings Host Loss% Snt Last Avg Best Wrst StDev 1. (waiting for reply) 2. 172.16.107.38 0.0% 51 6.1 43.8 3.4 350.9 82.5 
    17 条回复    2021-08-06 10:30:03 +08:00
    learningman
        1
    learningman  
       2021-08-05 19:37:08 +08:00 via Android   1
    trackroute 的原理是发送 TTL 递增的 ICMP 包
    privil
        2
    privil  
       2021-08-05 19:40:10 +08:00   1
    可以用 mtr
    Tianao
        3
    Tianao  
       2021-08-05 19:47:29 +08:00 via iPhone   1
    有些路由器不返回 ICMP 报文告知源主机 TTL 过期。
    freelancher
        4
    freelancher  
       2021-08-05 22:29:20 +08:00
    二楼说的应该是正确的。
    weyou
        5
    weyou  
       2021-08-05 23:02:35 +08:00 via Android
    @learningman 并不是! traceroute 默认发送的是 UDP 包
    rrubick
        6
    rrubick  
    OP
       2021-08-05 23:08:45 +08:00
    @learningman #1

    @weyou #5

    大佬能否详细说说
    weyou
        7
    weyou  
       2021-08-05 23:11:18 +08:00 via Android   1
    显示*号就是这个节点没有任何回应呗,可能是防火墙挡掉了,可以换用不用的 probe 方式,比如-I 或者-T 试试

    From `man traceroute`:
    This program attempts to trace the route an IP packet would follow to some internet host by launching probe packets with a small ttl (time to live) then listening for an ICMP "time exceeded" reply from a gateway. We start our probes with a ttl of one and increase by one until we get an ICMP "port unreachable" (or TCP reset), which means we got to the "host", or hit a max (which defaults to 30 hops). Three probes (by default) are sent at each ttl setting and a line is printed showing the ttl, address of the gateway and round trip time of each probe. The address can be followed by addi tional information when requested. If the probe answers come from different gateways, the address of each responding system will be printed. If there is no response within a certain timeout, an "*" (asterisk) is printed for that probe.
    rrubick
        8
    rrubick  
    OP
       2021-08-05 23:19:45 +08:00
    @Tianao #3
    用 TCP 和 UDP 也不返回吗?
    如果没收到 ICMP 报文或者 TTL 过期,就自动 TTL+1 发下一个报文吗?
    第一个图里为什么两次 traceroute 跳数不一致呢?
    rrubick
        9
    rrubick  
    OP
       2021-08-05 23:22:38 +08:00
    @weyou #7
    大佬麻烦看下上图里为什么跳数不一致呢?
    另附言里 3 种协议都试了,均无反应
    hahasong
        10
    hahasong  
       2021-08-06 00:02:52 +08:00   1
    这 Ping 它干啥,已知 AB 的 IP 和子网,分属不同的子网,能 ping 通说明两个子网相连,要通的话肯定第一跳是你的网关,最后一跳是 B 的网关
    Samuelcc
        11
    Samuelcc  
       2021-08-06 03:02:43 +08:00 via Android   1
    很多商业路由不会响应 traceroute,防止针对攻击。
    Tianao
        12
    Tianao  
       2021-08-06 08:09:53 +08:00 via iPhone
    @magic3584 #8 那就是源主机期望中间路由器返回一个 ICMP 目的不可达但路由器不一定返回,返不返回是可以配置的,与技术原理 /厂商实现没有必然关系。
    AllenHua
        13
    AllenHua  
       2021-08-06 08:41:23 +08:00 via iPhone
    Linux 下使用 traceroute 出现星号,一般原因是 linux 的 traceroute 默认使用 tcp 或 udp,强制使用 ICMP 就行了。https://hellodk.cn/post/19
    AllenHua
        14
    AllenHua  
       2021-08-06 09:07:26 +08:00   1
    ```
    # 大写的 I,指定 ICMP protocol
    $ traceroute -I example.com
    ```

    https://www.computerhope.com/unix/utracero.htm
    rrubick
        15
    rrubick  
    OP
       2021-08-06 10:14:37 +08:00
    @hahasong #10
    主要是刚又看了点网络的东西,就试着分析一下,结果跟我想的不太对。。。
    rrubick
        16
    rrubick  
    OP
       2021-08-06 10:15:44 +08:00
    @AllenHua #13
    附言里都使用了,结果差不多。。。
    rrubick
        17
    rrubick  
    OP
       2021-08-06 10:30:03 +08:00
    @privil #2
    已附言,看来结果都一样
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3199 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 04:47 PVG 12:47 LAX 20:47 JFK 23:47
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86