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 / 问题 / 417248
Accepted
Petr
Petr
Asked: 2018-01-16 06:27:11 +0800 CST2018-01-16 06:27:11 +0800 CST 2018-01-16 06:27:11 +0800 CST

DHCP 给出的客户端上 DNS 服务器的顺序

  • 772

我在本地网络中的 debian 8 服务器上运行 DNS 和 DHCP 服务器。
问题是客户端通过 DHCP 服务器以错误/不需要的顺序获取名称服务器。

DHCP 服务器配置:

subnet 192.168.10.0 netmask 255.255.255.0 {  
option routers 192.168.10.1;  
option subnet-mask 255.255.255.0;  
option domain-name-servers 192.168.10.1, 8.8.8.8, 8.8.4.4;  
option time-offset -18000;    
default-lease-time 21600;  
max-lease-time 43200;  
}  

其中 192.168.10.1 是 DNS 和 DHCP 服务器。

为客户端上的本地接口列出的名称服务器:

IP4.DNS[1]:                             8.8.8.8  
IP4.DNS[2]:                             8.8.4.4  
IP4.DNS[3]:                             192.168.10.1 

客户端是带有 isc-dhcp-client 的 Ubuntu 17.10

编辑:/etc/dhcp/dhclient.conf 的内容

send host-name = gethostname();
request subnet-mask, broadcast-address, time-offset, routers,
    domain-name, domain-name-servers, domain-search, host-name,
    dhcp6.name-servers, dhcp6.domain-search, dhcp6.fqdn, dhcp6.sntp-servers,
    netbios-name-servers, netbios-scope, interface-mtu,
    rfc3442-classless-static-routes, ntp-servers;

如何从 DHCP 服务器以正确的顺序获取名称服务器?
期望的顺序是首先使用本地名称服务器。
尔格:

IP4.DNS[1]:                             192.168.10.1   
IP4.DNS[2]:                             8.8.8.8  
IP4.DNS[3]:                             8.8.4.4
debian ubuntu
  • 2 2 个回答
  • 3800 Views

2 个回答

  • Voted
  1. Rui F Ribeiro
    2018-01-16T06:37:03+08:002018-01-16T06:37:03+08:00

    我不会对某些客户端 DHCP 守护程序优化首先提供具有公共 IP 地址的 DNS 服务器感到惊讶。

    但是,鉴于您对订单的坚持:

    我不建议依赖 DNS 答案顺序来提供不同的 DNS 视图或答案。

    至少在您需要这些问题的时候,将这些决策留给您的客户在本地基础设施中可能会导致一些不可预测的行为,尤其是考虑到负面的 DNS 缓存。它还将导致更大的 DNS 流量。您最终还会将 DNS 服务器加载到层次结构中,并询问有关您的内部域的问题。

    我建议设计一个深思熟虑的 DNS 基础结构,或者使用 Internet 和内部专用服务器,或者使用视图,并且至少有两个内部 DNS 服务器。

    TLDR 通过 DHCP 提供多个具有不同“世界”视图的 DNS 服务器并不会为服务带来更多稳定性,恰恰相反。

    • 3
  2. Best Answer
    Fox
    2018-01-16T10:10:01+08:002018-01-16T10:10:01+08:00

    与其试图控制客户端上 DNS 服务器的顺序,不如只通告内部 DNS 服务器会更干净。如果内部服务器配置为将它们无法满足的请求转发到给定的一组公共 DNS 服务器,则这是可能的。

    例如,我的 BIND9 配置(在 IP 上192.168.2.1)包含

    options {
        ...
        forwarders {
            208.67.220.220;
            208.67.222.222;
            8.8.8.8;
            8.8.4.4;
        }
        ...
    }
    

    或者(感谢@RuiFRibeiro),您可以使用区域块与根名称服务器进行通信:

    zone "." IN {
        type hint;
        file "root.hint"
    }
    

    (您的发行版可能使用db.root而不是root.hint)。

    在任一配置中,如果服务器无法确定所请求名称的 IP,它会尝试联系另一台服务器,无论是定义的服务器forwarders还是根名称服务器,以找到适当的 IP。换句话说,总是先尝试本地服务器,如果失败,则使用不同的服务器作为替代。

    然后dhcpd.conf选项很简单

    option domain-name-servers 192.168.2.1;
    

    如果您配置多个冗余本地 DNS 服务器,则可以在dhcpd配置中指定每个服务器,而不必担心它们的顺序,因为它们的行为都相同。

    • 3

相关问题

  • GRUB 配置以识别同一 Linux 发行版的不同桌面环境(安装)

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 如何在拼音输入法中输入ü?

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