V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
TheCure
V2EX  ›  程序员

如何探测链路的 MTU?

  •  
  •   TheCure · 2015-04-02 20:31:25 +08:00 · 6649 次点击
    这是一个创建于 3523 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需要探测链路的MTU,初步想法是手动构造一个ICMP报文,并设置不分片,逐步增大报文大小,当收到要求分片的错误信息时候便是MTU的大小.
    因为是要重头构造,所以直接在python里调用command('ping -f')的不行.构造ICMP报文需要用到RAW SOCKET:
    1.使用socket.IPPROTO_ICMP的时候内核接管了IP头默认分片没有方法设置DF为1.
    2.使用socket.IPPROTO_RAW的时候自己构造的IP头如果DF为1就发不出去,DF为0才可以发出去.
    总之RAW socket始终是自动分片的,这样就没有办法探测MTU了,出了RAW_SOCKET还有什么方法可以实现MTU探测?

    11 条回复    2015-04-03 11:07:38 +08:00
    thekll
        1
    thekll  
       2015-04-02 21:31:46 +08:00 via iPhone
    geeklian
        2
    geeklian  
       2015-04-02 21:53:44 +08:00
    why not google?
    geeklian
        3
    geeklian  
       2015-04-02 22:00:58 +08:00   ❤️ 1
    TheCure
        4
    TheCure  
    OP
       2015-04-02 22:27:48 +08:00
    @thekll 我说的方法其实就是RFC的方法,只是我不知道怎么设置DF为1来禁止分包
    invite
        5
    invite  
       2015-04-02 22:44:47 +08:00
    你发送了多大的ICMP包?然后设置的DF为1?
    TheCure
        6
    TheCure  
    OP
       2015-04-02 23:01:20 +08:00
    @invite 一个一个加 可以ping通的话就加一个从1280开始
    ceyes
        8
    ceyes  
       2015-04-03 01:06:11 +08:00 via Android
    不是有 tracepath 么?
    另,ping -M do 就是禁止分片。
    zhicheng
        9
    zhicheng  
       2015-04-03 10:04:19 +08:00 via Android   ❤️ 1
    @callofmx 是一个一个减,从本地 NIC 的 MTU 开始,如果没有回复,就用下一个仅小于这个 MTU 的设备 MTU尺寸。最小到 576 应该就可以了。
    TheCure
        10
    TheCure  
    OP
       2015-04-03 11:05:42 +08:00
    @zhicheng 总是无法探测大于本机MTU值的链路MTU,所以你说的更科学一点,感谢!
    TheCure
        11
    TheCure  
    OP
       2015-04-03 11:07:38 +08:00
    @dndx 这就是我想要的答案! 感谢,我查查这个方法在python中有没有类似的
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   912 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 22:02 · PVG 06:02 · LAX 14:02 · JFK 17:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.