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 / 问题 / 400736
Accepted
larsks
larsks
Asked: 2012-06-21 13:34:25 +0800 CST2012-06-21 13:34:25 +0800 CST 2012-06-21 13:34:25 +0800 CST

应用于本地目的地流量时,DNAT 和 REDIRECT 是否等效?

  • 772

在设置我们的 OpenStack 环境时,我遇到了一个问题,该问题阻止实例联系主机上运行的服务器。元数据服务(公开 HTTP API)在主机的 8775 端口上运行,OpenStack 网络代码添加以下 DNAT 规则以通过端口 80 上的特殊地址授予访问权限:

-A PREROUTING -d 169.254.169.254/32 
  -p tcp -m tcp --dport 80 -j DNAT --to-destination 127.0.0.1:8775 

实例通过本地桥接设备连接到主机,并169.254.169.254分配给lo.

虽然此规则成功匹配来自尝试访问的来宾实例的数据包http://169.254.168.254/,但它们永远不会到达侦听服务。

用基本等效的 REDIRECT 替换此 DNAT 规则可以使一切正常工作:

-A PREROUTING -d 169.254.169.254/32 
  -p tcp -m tcp --dport 80 -j REDIRECT --to-ports 8775 

我试图理解为什么 REDIRECT 起作用而 DNAT 失败。从 iptables 文档中不清楚该DNAT规则是否适用于本地目标流量。我希望这里有人可以提供权威的答案,最好有文档支持,或者可以建议我的配置中可能有什么问题会阻止 DNAT 规则按预期工作。

networking nat iptables openstack
  • 2 2 个回答
  • 2123 Views

2 个回答

  • Voted
  1. Best Answer
    bahamat
    2012-06-21T14:15:09+08:002012-06-21T14:15:09+08:00

    您正在尝试做的事情被内核明确拒绝。

    您不能将数据包从非 127/8 地址发送到 127/8。内核将它们过滤掉并丢弃,因为它认为它们是“火星人”。

    这大概是因为rp_filter默认为开。可能禁用它可能会改变此行为(尽管这将禁用一些潜在的关键安全保护)。

    使用 REDIRECT,您不会更改 IP,这就是它起作用的原因。换句话说,如果您要使用 DNAT,您可以将它发送到127.0.0.0/8以外的任何地方。

    • 3
  2. mgorven
    2012-06-21T14:00:05+08:002012-06-21T14:00:05+08:00

    根据netfilter NAT HOWTO:

    Destination NAT 有一种特殊情况称为重定向:它是一种简单的便利,完全等同于对传入接口的地址进行 DNAT。

    它稍微智能一些,因为它选择 DNAT 目标地址作为接收数据包的设备地址。在您的情况下,它将 DNAT 数据包发送到桥接设备上的地址,而不是 127.0.0.1。

    • 2

相关问题

  • 谁能指出我的 802.11n 范围扩展器?

  • 我怎样才能得到一个网站的IP地址?

  • 在一个 LAN 中使用两台 DHCP 服务器

  • 如何在 Linux 下监控每个进程的网络 I/O 使用情况?

  • 为本地网络中的名称解析添加自定义 dns 条目

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