V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
fengkuangdedoufu
V2EX  ›  Linux

如何使用 linux iptables 来进行不对等的范围端口转发呢?

  •  
  •   fengkuangdedoufu · 2016-09-30 12:07:08 +08:00 · 2829 次点击
    这是一个创建于 2958 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如将服务器端口 50000:60000 转发到 IP 为 1.2.3.4 的 10000:20000 这样可以吗?同样的端口倒是可以,这样不知道行不行。用 iptables
    9 条回复    2016-09-30 18:13:41 +08:00
    fengkuangdedoufu
        1
    fengkuangdedoufu  
    OP
       2016-09-30 12:13:19 +08:00
    都准备给祖国母亲庆生了。
    qqmishi
        2
    qqmishi  
       2016-09-30 12:15:56 +08:00 via Android
    你可以写 10000 个规则把端口一一对应,,,
    fengkuangdedoufu
        3
    fengkuangdedoufu  
    OP
       2016-09-30 12:18:06 +08:00
    @qqmishi … 这是不得已的情况吧。要是真这样,我宁愿用 socat 然后写个 FOR 循环来执行。。。
    airqj
        5
    airqj  
       2016-09-30 14:47:12 +08:00
    用--to-ports 参数
    fengkuangdedoufu
        6
    fengkuangdedoufu  
    OP
       2016-09-30 16:31:46 +08:00
    @tywtyw2002 感谢看起来有点吃力。能不能写一个 demo
    fengkuangdedoufu
        7
    fengkuangdedoufu  
    OP
       2016-09-30 16:32:00 +08:00
    @airqj 感谢回复,能写一个具体的例子吗
    airqj
        8
    airqj  
       2016-09-30 18:08:08 +08:00
    @fengkuangdedoufu
    iptables -t nat -A POSTROUTING -p tcp --dport 2000:3000 -s 192.1
    68.31.50 -j MASQUERADE --to-ports 1000-2000
    airqj
        9
    airqj  
       2016-09-30 18:13:41 +08:00
    iptables -t nat -A PREROUTING -p tcp --dport 1000:2000 -j DNAT -
    -to-destination 192.168.1.100:2000-3000
    demo ,具体的你试着改一下
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3234 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 12:24 · PVG 20:24 · LAX 04:24 · JFK 07:24
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.