如何主动修改所有的出站 ACK 包的源 ip? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
eastpiger
V2EX    问与答

如何主动修改所有的出站 ACK 包的源 ip?

  •  
  •   eastpiger 2017-01-27 10:09:27 +08:00 3955 次点击
    这是一个创建于 3211 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需求目标:服务器已经配置了一个内网 ip ,假设是 1.1.1.1 ,同时还分配了一个公网 ip2.2.2.2,我想实现的效果是:无论什么样的请求到服务器,其 ACK 包的源 ip 全部修改为公网 ip2.2.2.2 。

    尝试过在 iptables 的 POSTROUTING 中 SNAT 出站包并修改 ip ,但是实测这样只能修改本机主动发出的包,而对收到的请求的回复( ACK)包没有效果。

    不知道有没有哪位有可行方向的建议?

    第 1 条附言    2017-01-27 11:37:45 +08:00
    解释一下:

    这是我现在服务器所在的网络状态:(其中路由实际上是做了一个不完整的端口转发)




    而这是我希望实现的效果:(红框就是我想做的)

    22 条回复    2017-01-28 09:47:48 +08:00
    lhbc
        1
    lhbc  
       2017-01-27 10:19:20 +08:00 via iPhone
    删掉内网 IP
    eastpiger
        2
    eastpiger  
    OP
       2017-01-27 10:26:21 +08:00
    @lhbc #1 ACK 包的请求来源来自于内网 ip ,就这么删了肯定是要出问题的。。。
    lcdtyph
        3
    lcdtyph  
       2017-01-27 10:43:30 +08:00
    你的意思是修改 tcp 的第二个包的源 ip 么?
    可是这么做没有任何意义啊,如果第二个包回应用的是内网 ip ,说明第一个 SYN 包的目的地址就是内网 ip ,你强行改成公网 ip 回应让客户端怎么应答啊= =
    treo
        4
    treo  
       2017-01-27 10:49:18 +08:00
    @lcdtyph 对方不会应答,直接 drop
    lcdtyph
        5
    lcdtyph  
       2017-01-27 10:52:05 +08:00
    @treo 所以我觉得 lz 的目的没啥意义嘛,如果他不想让别人用内网 ip 连接服务器就直接把目的地址是内网 ip 的包 reject 掉好了= =||
    eastpiger
        6
    eastpiger  
    OP
       2017-01-27 11:04:46 +08:00
    @lcdtyph #5 是这样的,我们的上级路由指向我的公网 ip 映射的时候没有做回源,于是产生了这样的情况:

    内网 1.1.1.2 访问公网 2.2.2.2 ,发到路由器,路由器执行 DNAT 改为 1.1.1.2 发往 1.1.1.1 ,

    服务器收到消息,发送第二次握手,从 1.1.1.1 发往 1.1.1.2 ,客户端 DROP

    而我这样修改了源 ip 之后就变成了:

    服务器收到消息,发送第二次握手,从 1.1.1.1 发往 1.1.1.2 ,被我强制修改为 2.2.2.2 发往 1.1.1.2 ,客户端发回 ACK ,建立连接。
    msg7086
        7
    msg7086  
       2017-01-27 11:08:54 +08:00
    为啥不是被路由器 DROP ?
    eastpiger
        8
    eastpiger  
    OP
       2017-01-27 11:09:05 +08:00
    @lcdtyph #3 严格来说,我不仅想修改 SYN/ACK 包,我还想修改掉所有的 ACK 包,也就是这个服务器以后对外的联络全部都用公网 ip 的身份实现(以解决路由那边不做 SNAT 只做 DNAT 的问题),但是收到消息却都是从内网 ip 收到的(这一部分我改不了,上游路由也改不了)

    这样服务器的网站以后再内网用内网 ip 就访问不了了,原因正如您所说的那样。但是好处在于我们的公网 ip 无论在公网还是在内网都能访问了。这样我 DNS 好歹能正常 work 。算是至少能用的一种方案吧
    jasontse
        9
    jasontse  
       2017-01-27 11:10:15 +08:00 via iPad
    1.1.1.1: mdzz 2.2.2.2 我没找你啊

    连接建立失败
    eastpiger
        10
    eastpiger  
    OP
       2017-01-27 11:12:54 +08:00
    @jasontse #9 1.1.1.1 就是 2.2.2.2 、你确定没理解错么?

    是 1.1.1.2 连接 2.2.2.2 ,被路由修改为 1.1.1.2 连接 1.1.1.2 ,然后服务器收到回复 1.1.1.1 到 1.1.1.2 ,被我改成 2.2.2.2 回复 1.1.1.2 ,建立连接成功。
    lcdtyph
        11
    lcdtyph  
       2017-01-27 11:16:14 +08:00
    @eastpiger 抱歉没有网络拓扑图我好像没太看懂您的描述……
    eastpiger
        12
    eastpiger  
    OP
       2017-01-27 11:19:24 +08:00
    @lcdtyph #11
    eastpiger
        13
    eastpiger  
    OP
       2017-01-27 11:21:26 +08:00
    @lcdtyph #11 我希望强行修改后实现这样的效果:(红框这里)

    gulucn
        14
    gulucn  
       2017-01-27 11:29:28 +08:00 via Android
    感觉你想的东西跟 http://m.chinabyte.com/soft/25/13169025_m.shtml 里面的第三种负载均衡方法相似
    lcdtyph
        15
    lcdtyph  
       2017-01-27 11:42:26 +08:00
    @eastpiger 抱歉……才疏学浅,没想到什么办法
    realityone
        16
    realityone  
       2017-01-27 13:28:13 +08:00
    在 PREROUTING 里再加一条 DNAT 到 2.2.2.2 呢?
    eastpiger
        17
    eastpiger  
    OP
       2017-01-27 13:50:14 +08:00 via Android
    @realityone 这个倒是没试过。。可是这个有什么关系么?出站的时候是 MAS 改成网卡 ip 了吧
    zhjits
        18
    zhjits  
       2017-01-28 00:46:38 +08:00
    你这样改了以后包首先会被你的出口路由器干掉
    yankebupt
        19
    yankebupt  
       2017-01-28 01:43:25 +08:00 via Android
    在服务器本机上拦截所有入站到 1.1.1.1 包并真的把他们发到 2.2.2.2 不知道可行不(相当于 cancel 掉了路由对于之前目标地址的修改)(前提你的服务程序能绑定 2.2.2.2 )因为看别人好像这么干过……如果做不到,估计你需要更新一下拓扑图说明一下或者说明一下为什么不能绑定 2.2.2.2 的原因了…(或者说明一下我的做法的错误之处…毕竟不是专业的)
    yankebupt
        20
    yankebupt  
       2017-01-28 01:46:01 +08:00 via Android
    @realityone 忘了看,上面好像有人说过了
    ryd994
        21
    ryd994  
       2017-01-28 08:08:11 +08:00 via Android
    懂不懂什么叫 TCP 四元组?
    mengskysama
        22
    mengskysama  
       2017-01-28 09:47:48 +08:00 via iPhone
    这个拓扑不全吧,服务器回包到上级路由肯定回 drop 掉伪造源地址的包。除非经过特殊配置。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5265 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 07:49 PVG 15:49 LAX 23:49 JFK 02:49
    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