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
    • 最新
    • 标签
主页 / server / 问题 / 793723
Accepted
Crash Override
Crash Override
Asked: 2016-08-04 13:48:29 +0800 CST2016-08-04 13:48:29 +0800 CST 2016-08-04 13:48:29 +0800 CST

Red Hat/CentOS Linux 中禁止某个 IP 范围外网

  • 772

我有一个 VPN,我的服务器经常将数据发送到通过 VPN 路由的私有 IP 地址。当 OpenVPN 建立或终止时,它会启用/禁用路由。

我想通过主 Internet 接口 (eth0) 将该私有 IP 范围设为空路由。有没有一种简单的方法可以在不干扰来自 VPN 软件的路由命令的情况下做到这一点?

iptables 不会这样做。我试过了

iptables -A OUTPUT -i eth0 -p tcp -d 192.168.0.0/16 -j REJECT

但是在输出链中指定接口时 iptables 不起作用。

任何人都知道是否有一种方法可以仅将虚拟路由添加到特定接口(eth0),而不会干扰可能正在使用该路由的其他接口?

Ps-我知道 192.168.0.0/16 不是 INTERNET 可路由的,但出于安全原因,希望确保在其他本地服务器或网络设备开始侦听私有子网的极少数情况下没有数据流出。

centos iptables static-routes
  • 3 3 个回答
  • 217 Views

3 个回答

  • Voted
  1. Best Answer
    Michael Hampton
    2016-08-04T13:54:06+08:002016-08-04T13:54:06+08:00

    您在 iptables 规则中的接口规范是落后的。

    您指定:

    iptables -A OUTPUT -i eth0 -p tcp -d 192.168.0.0/16 -j REJECT
    

    Using-i匹配在指定接口上进入系统的流量。

    相反,您希望在命名接口上匹配离开系统的流量,这是使用-o.

    iptables -A OUTPUT -o eth0 -p tcp -d 192.168.0.0/16 -j REJECT
    

    (你可能不希望-p tcp在那里,否则非 TCP 流量可能会通过。)

    • 5
  2. Tero Kilkanen
    2016-08-04T17:32:03+08:002016-08-04T17:32:03+08:00

    除了迈克尔的回答,我认为应该阻止链中的流量FORWARD,因为该OUTPUT链仅适用于本地生成的数据包并从防火墙出去。据我所知,它不适用于路由数据包。

    • 2
  3. GnP
    2016-08-09T15:50:01+08:002016-08-09T15:50:01+08:00

    您已经得到了使用 iptables 所需的答案。

    如果您想使用路由,一个好方法是为 192.168.0.0/16 设置路由并让您的 vpn 服务器向您发送两条更具体的路由,在您的情况下,两条路由将是 192.168.0.0 /17 和 192.168.128.0/17

    /16 路由将是固定的和空路由:

    ip route add blackhole 192.168.0.0/16
    

    您的 vpn 服务器(或 vpn-up 脚本)将为您提供其他服务:

    ip route add 192.168.0.0/17 via <VPNGW>
    ip route add 192.168.128.0/17 via <VPNGW>
    

    这实际上是def1OpenVPN 中的选项在不干扰现有路由的情况下覆盖默认网关的作用。

    • 2

相关问题

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 使用 crontab 和 /etc/cron.hourly,daily,weekly 的区别

  • 持续监控许多服务器运行状况的简单方法?

  • Hudson 无法在 tomcat5 中启动

  • CentOS 的依赖挑战

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve