V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
cwbsw

策略路由如何处理本机流量?

  •  
  •   cwbsw · Jul 6, 2018 · 1039 views
    This topic created in 2851 days ago, the information mentioned may be changed or developed.
    iptables -t mangle -A OUTPUT -m set --match-set vpn dst -j MARK --set-mark 0x88
    iptables -t mangle -A PREROUTING -m set --match-set vpn dst -j MARK --set-mark 0x88
    ip route add default dev vpn table 88
    ip rule fwmark 0x88 lookup 88
    

    一直以来都是用如上方式在路由器上部署 vpn 科学上网,本机产生的流量也都能正确分流。 今天突然想到这样做了两次 NAT,于是在路由器上去掉了 vpn 接口的 NAT 规则,然后在 vps 上配置到 lan 侧的路由后,在 lan 上的设备就能正常通过 vpn 访问外网了,但是路由器本身的流量却出现了异常,在 vpn 接口上能看到发包,但是源地址却是 pppoe-wan 的,这样自然回程就不通了。但是

    ip rule to 8.8.8.8 lookup 88

    或者

    ip route add 8.8.8.8 dev vpn

    又都能让本机到 8.8.8.8 的流量正常走 vpn 接口。

    所以这个的原理是什么?该如何让本机流量根据 MARK 分流呢?

    3 replies    2018-07-07 20:18:53 +08:00
    LGA1150
        1
    LGA1150  
       Jul 7, 2018 via Android
    ip route add default dev vpn table 88 src <vpn 接口地址>
    cwbsw
        2
    cwbsw  
    OP
       Jul 7, 2018
    @LGA1150
    这样还是不行啊,奇怪的是 ip rule to 8.8.8.8 lookup 88 就能行得通,有 MARK 的包也确实是从 vpn 接口发出去了。
    cwbsw
        3
    cwbsw  
    OP
       Jul 7, 2018
    似乎 Linux 协议栈选择路由决定源地址是在 OUTPUT 链之前,查询的是默认路由表,所以要改变本机流量的源地址只能做 NAT。
    https://upload.wikimedia.org/wikipedia/commons/3/37/Netfilter-packet-flow.svg
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5746 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 41ms · UTC 07:10 · PVG 15:10 · LAX 00:10 · JFK 03:10
    ♥ Do have faith in what you're doing.