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 / 问题 / 1172871
Accepted
nobody
nobody
Asked: 2025-02-17 19:23:51 +0800 CST2025-02-17 19:23:51 +0800 CST 2025-02-17 19:23:51 +0800 CST

为内部使用而命名并转发特定子域名

  • 772

我们在受保护的环境中拥有 DNS 服务器,无法访问互联网,这些服务器仅解析我们编写的内部域。这些内部 DNS 服务器中的 root.servers 文件为空:

zone "."
{
  type hint;
  file "root.servers"; // root.server is empty file
};

这样,内部 DNS 仅解析内部名称。

然后我们在 DMZ 中有 DNS 服务器,它将内部域转发到 dmz,如下所示:

zone "internal" in
  type forward;
  forwarders { 10.10.10.1; 10.10.10.2; }; // internal DNSes
};

DMZ 中的这些 DNS 还会从解析互联网域的 DNS 转发互联网地址,如下所示:

zone "." in {
  type forward;
  forwarders { 172.20.10.1; 172.20.20.2; }; // DNSes resolving internet domains
};

这样,DMZ 中的 DNS 就可以解析内部和互联网域。多年来,它一直都是这样运作的。

现在,我们需要为 DMZ 中的某些服务器获取知名 CA 签名的证书。为此,我们创建了一个互联网子域。我们将其命名为 dmz.example.com。

我们在 DMZ 名称服务器中创建了一个区域 dmz.example.com,DMZ 解析这些域名。我们也想在内部网络中解析这些域名。为此,我们打开了从内部到 DMZ 的 DNS 访问,并在内部 DNS 中添加了一个区域,如下所示:

zone "dmz.example.com" in
{
  type forward;
  forwarders { 10.100.1.1; 10.100.1.2; }; // DMZ DNSes
};

现在,内部 DNS 无法解析 dmz.example.com,也无法访问 DMZ DNS 以获取有关此域的信息。我不明白为什么内部 DNS 不使用该区域配置?这是否与空的 root.servers 文件和区域“。”有关?

在 DMZ DNS 转发内部域的另一个方向上它可以工作。

bind
  • 2 2 个回答
  • 46 Views

2 个回答

  • Voted
  1. nobody
    2025-02-19T18:17:14+08:002025-02-19T18:17:14+08:00

    我找到了一个解决方案,但我不确定我是否满意它,而且我对它了解得不是很好。

    正如我在问题中写到的,内部 DNS 的 root.servers 文件是空的。这意味着所有针对互联网域的查询都会立即返回,没有任何答案。

    我发现的解决方案是内部 DNS 不再使用 root.servers 文件,如下所示:

    zone "."
    {
      type hint;
      file "root.servers"; // root.server is empty file
    };
    

    相反,我将“。”区域配置为转发区域:

    zone "."
    {
      type forward;
      forwarders { 10.10.10.254; }; // non-existing IP
    };
    

    随着“。”区域处理的改变,区域 dmz.example.com 也开始在内部 DNS 中工作。

    我并不是 100% 满意该解决方案,因为内部 DNS 现在会尝试访问不存在的 IP 来获取有关 Internet 域的信息。以前,查询仅限于本地空文件 root.servers。现在,DNS 会尝试连接到不存在的 IP,然后返回空答案。如果我选​​择该 IP 不当,防火墙将忙于处理请求。如果有一天 IP 被占用,网络上的新设备将开始接收 DNS 查询。也许我可以创建一个虚拟接口来发送请求。这样,它就不会从计算机传到网络。

    有人知道怎样才能让它在不转发“。”区域的情况下工作吗?

    • 0
  2. Best Answer
    nobody
    2025-03-04T18:18:10+08:002025-03-04T18:18:10+08:00

    我找到了一个更好的解决方案,forward only;即向转发的外部区域添加配置行:

    zone "dmz.example.com" in
    {
      type forward;
      forward only;
      forwarders { 10.100.1.1; 10.100.1.2; }; // DMZ DNSes
    };
    
    • 0

相关问题

  • 配置仅在短时间内缓存的本地 DNS 解析器

  • BIND 服务器无法解析 us3.php.net!

  • DNS - 有什么方法可以强制名称服务器更新域的记录?

  • BIND/Named:禁用递归,客户端使用替代服务器

  • DR 站点中 Windows 域的 BIND

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