AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 436331
Accepted
Welite
Welite
Asked: 2018-04-09 03:52:46 +0800 CST2018-04-09 03:52:46 +0800 CST 2018-04-09 03:52:46 +0800 CST

iptables 和多个 nat 重定向

  • 772

我的机器上有大约 20 个 VPS(在本地 IP 上运行),我正在使用 iptables 在这些 VPS 上使用脚本重定向某些端口,如下所示:

iptables -t nat -A PREROUTING -p tcp -d %hostIP% --dport %real_port% -i eth0 -j DNAT --to-destination %vps_local_ip%":%vps_destination_port%

为了刷新(创建或删除新 vps),我必须像运行 2000 条 iptables 命令一样运行,首先我删除所有规则,然后再次插入它们,有时会跳过一些命令,因为 iptables 无法快速处理它,添加一个间隔不是一个选项,因为我需要快速完成这些命令。

这个问题有更好的解决方案吗?

iptables virtual-machine
  • 2 2 个回答
  • 1424 Views

2 个回答

  • Voted
  1. Best Answer
    Hauke Laging
    2018-04-09T05:22:37+08:002018-04-09T05:22:37+08:00

    当一个 VPS 发生变化时,我认为没有理由重置所有规则。除非您的意思是每个 VPS 有 2000 个命令,但在这种情况下,我会假设您做错了什么。

    一般来说,我建议您为每个 VPS 设置两条链,一条是活动的,一条是非活动的。如果您真的需要在两个命令之间等待,iptables那么就这样做——同时配置非活动链。完成此操作后,您将主链中的引用从活动链更改为非活动链(可能PREROUTING)。

    如果您使用许多iptables命令来检查哪个 VPS 是目标,那么您可以开始使用ipset以通过单个命令完成此操作。

    例子

    您为所有活动链和所有非活动链创建两个链。这允许在没有竞争条件的情况下进行更改。

    iptables -t nat -I PREROUTING 1 -j chaingroup_a
    
    iptables -t nat -A chaingroup_a -j vps_1a
    iptables -t nat -A chaingroup_a -j vps_2a
    iptables -t nat -A chaingroup_a -j vps_3a
    iptables -t nat -A chaingroup_a -j ACCEPT # stop applying rules
    
    iptables -t nat -A vps_1a -d 1.2.3.4 -p tcp --dport 42 -j DNAT --to-destination 10.1.2.3:4242
    

    如果要更改配置,则重置非活动链并配置它们:

    iptables -t nat -F chaingroup_b
    iptables -t nat -F vps_1b
    iptables -t nat -F vps_2b
    iptables -t nat -F vps_3b
    
    iptables -t nat -A chaingroup_b -j vps_1b
    iptables -t nat -A chaingroup_b -j vps_2b
    iptables -t nat -A chaingroup_b -j vps_3b
    iptables -t nat -A chaingroup_b -j ACCEPT # stop applying rules
    
    iptables -t nat -A vps_1a -d 1.2.3.4 -p tcp --dport 4321 -j DNAT --to-destination 10.1.2.3:12345
    

    准备好后,将非活动链组变为活动链组:

    iptables -t nat -I PREROUTING 1 -j chaingroup_b
    

    由于-j ACCEPT在末尾chaingroup_b仍然存在chaingroup_a被忽略。但是您无论如何都应该删除它,以防止PREROUTING每次更改都增长:

    iptables -t nat -D PREROUTING 2
    
    • 2
  2. MTG
    2018-04-09T05:10:23+08:002018-04-09T05:10:23+08:00

    事实上,iptables 可以做得足够快,我已经测试了近 1900 条规则。您只需要在列表文件中跟踪 ip:ports,然后编写一个脚本,例如如下所示的 bash 脚本,然后从该文件重新加载 ip:port's

    我假设文件中的每一行都类似于 realport:vps-ip:port

    #/bin/bash
    HOST=100.200.100.200 # your public address
    LIST=/path/to/file
    
    iptables -t nat -F
    cat "$LIST" | while read line
    do
    realport=`echo $line|cut -f1 -d:`
    vpsip=`echo $line|cut -f2 -d:`
    port=`echo $line|cut -f3 -d:`
    iptables -t nat -A PREROUTING -p tcp -d $HOST --dport $realport -i eth0 -j DNAT --to-destination $vpsip:$port
    done
    
    iptables save
    

    这样你只需要处理列表。您还可以使用其他格式来代替 realport:vps-ip:port,例如使其以逗号分隔。然后将 -d: 更改为 -d 或其他任何内容。

    • 1

相关问题

  • 持久的 iptables

  • 如何在运行时从命令行更改 KVM VNC 端口?

  • Iptables 规则允许 appVM 通过配置为仅通过 QubesOS 中的 VPN 的 proxyVM

  • 如何在 Linux 中让所有流量通过一个接口

  • LXC 容器内部从零开始的 Linux

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve