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 / 问题 / 397835
Accepted
Adrien Clerc
Adrien Clerc
Asked: 2012-06-13 00:35:04 +0800 CST2012-06-13 00:35:04 +0800 CST 2012-06-13 00:35:04 +0800 CST

同一 IPv4 地址上的多个权威 DNS 服务器

  • 772

我想在我位于 example.com 的自托管服务器上维护一个 DNS 隧道。我还有一个 DNS 服务器,它为 example.com 提供一切服务。我目前在域 tunnel.example.com 上使用dns2tcp进行 DNS 隧道传输。 NSD3用于为权威区域提供服务,因为它既简单又安全。

但是,我只有一个公共 IPv4 地址,这意味着 NSD 和 dns2tcp 不能监听同一个 IP/端口。

所以我目前正在使用PowerDNS Recursor使用这样的forward-zones参数:

forward-zones-recurse=tunnel.example.com=1.2.3.4:5354
forward-zones=example.com=1.2.3.4:5353

这使得对权威区域的请求能够被请求到正确的服务器,以及隧道请求。NSD 监听 5353 端口,dns2tcp 监听 5354 端口。

然而,这很糟糕,因为递归需要打开。它实际上回答了任何递归查询。

你有什么解决办法吗?我真的更喜欢不涉及设置 BIND 的解决方案,但如果您有心情说服我,请毫不犹豫地这样做;)


编辑:我将标题更改为更清楚。

domain-name-system forwarding tunneling authoritative recursive
  • 2 2 个回答
  • 2498 Views

2 个回答

  • Voted
  1. voretaq7
    2012-06-13T07:31:05+08:002012-06-13T07:31:05+08:00

    两台服务器不能同时监听同一个 IP+端口组合。
    你为这样一个有两个后卫的野兽所做的任何事情都是Hackery——这是错误的,不应该做的。痛苦、悲伤、疯狂和死亡横亘在这条路上——现在回头,否则你会被一只咕噜咕噜吃掉。


    正确的解决方案

    获取另一个IP。理想情况下完全获得另一台服务器,并且不要在与权威服务器相同的机器上运行递归 DNS。


    简单的解决方案

    克服对 BIND 的恐惧/不信任/仇恨(获取DNS 和 BIND的副本并做好准备),并使用该allow-recursion{…};指令来限制可以进行递归查询的人员。

    这个简单的解决方案可能仍然会让您面临缓存中毒和其他问题。如果你真的想要你的权威 DNS 服务器的安全,你需要运行一个单独的名称服务器进程来监听一个单独的 IP 地址,最好是在一个单独的主机(或监狱,VM,等等)上。

    • 1
  2. Best Answer
    Adrien Clerc
    2012-06-20T00:53:53+08:002012-06-20T00:53:53+08:00

    2021 年更新

    来自(见下文)的string模块的解决方案不能用 翻译,所以我不得不找到另一个解决方案。iptablesnftables

    我现在正在使用dnsdist,它是一个 DNS 负载平衡器。它使用更多的 CPU 和 RAM,但显然更强大。我喜欢它专注于这项任务,除非有要求,否则无需重写 DNS 答案。这是我的配置文件的摘录:

    -- dnsdist configuration file, an example can be found in /usr/share/doc/dnsdist/examples/
    
    -- disable security status polling via DNS
    setSecurityPollSuffix("")
    
    setLocal('<PUBLIC_IP4>:53', {reusePort=true, interface="eth_adsl"})
    addLocal('[<PUBLIC_IP6>]:53', {reusePort=true, interface="eth_adsl"})
    setACL({'0.0.0.0/0', '::/0'})
    
    controlSocket('127.0.0.1')
    setKey("SECRET_KEY")
    
    -- Declare NSD authoritative server. It could also listen to localhost, but I let it answer on public addresses, using port 5300
    newServer({address="[<PUBLIC_IP6>]:5300", checkInterval=60, pool="root"})
    newServer({address="<PUBLIC_IP4>:5300", checkInterval=60, pool="root"})
    
    -- Declare DNS Tunnel (iodine), on port 5354
    newServer({address="127.0.0.1:5354", pool="tunnel"})
    -- This is using socket activation, so disable dnsdist checks to avoid waking up the tunnel
    getServer(2):setUp()
    
    -- Forward to tunnel, skipping cache
    tunnelRule = makeRule("t.antipoul.fr")
    addAction(tunnelRule, SkipCacheAction())
    addAction(tunnelRule, PoolAction("tunnel"))
    
    -- Allow Zone transfer from secondary only
    -- See https://dnsdist.org/advanced/axfr.html
    addAction(AndRule({OrRule({QTypeRule(DNSQType.AXFR), QTypeRule(DNSQType.IXFR)}), NotRule(makeRule("<SECONDARY_IP4>/32"))}), RCodeAction(DNSRCode.REFUSED))
    
    -- All remaining traffic goes to NSD
    addAction(AllRule(), PoolAction("root"))
    

    原始 2012 解决方案

    我找到了解决问题的方法。但是,它不是该问题的通用解决方案。

    在我的例子中,我依赖于 dns2tcp 使用的协议,它使用 tunnel.example.com 上的子域请求进行通信。所以想法是匹配包含此类请求的数据包,并构建一个 netfilter 规则:

    iptables -t nat -I PREROUTING -p udp --dport 53 -m string --algo bm --from 42 --hex-string "|0674756e6e656c076578616d706c6503636f6d00|" -j REDIRECT -to-ports 5354
    
    • 该hex-string参数是对应 tunnel.example.com于 DNS 数据包中所见的字符串。
    • 这from 42确保只有子请求被重定向到 dns2tcp,而不是域本身的常规请求,例如 SOA 或 NS 请求。
    • NSD 现在监听 53 端口,比以前好多了。
    • 没有更多的公共递归服务器,这更好。

    这并不完美,但它确实比以前使用了更少的软件。

    • 0

相关问题

  • Solaris DNS

  • resolv.conf 在经过一段时间后被更改

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • 为本地网络中的名称解析添加自定义 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