当我没有在 dhclient.conf 中定义时,我的 DHCP 服务器如何知道我机器的主机名?

Mik*_*oss 13 domain-name-system dhcp linux ubuntu

我正在尝试解决一些与我们网络上的 DHCP 相关的时髦 DNS 问题(我怀疑我们目前有不止一个 DHCP 服务器在运行),在尝试解决这个问题时,我注意到我刚刚使用的新服务器有些奇怪设置。

有问题的服务器是运行 Ubuntu 9.10 Server 的 Xen 虚拟机。物理 Xen 服务器也在我们的网络上,当我第一次在 Xen 中启动 VM 时(我从运行在我机器上的本地 Virtualbox VM 导入它,它在不同的网络上运行),它有一个从我们的办公网络租用 DHCP,一切都很好。

我检查了dhclient.eth0.leases文件以查看配置的内容,并看到机器所在的先前网络的旧 DHCP 租用仍然存在,以及它当前连接到的办公网络的新 DHCP 租用。我立刻注意到了两件事:

  1. 来自先前网络的旧 DHCP 租用信息没有options host-name一行,我认为这意味着 VM 的原始 VirtualBox 版本没有将此选项发送到 DHCP 服务器。或者这是否意味着旧的 DHCP 服务器不支持 DHCP 主机名选项?当时它正在使用 VirualBox 的内部 DHCP 服务器......

  2. 新的 DHCP 租用信息确实options host-name一行,其中包括服务器的正确当前主机名(“fozzie”)。如果我理解正确,这意味着服务器将其主机名发送到我们网络上的 DHCP 服务器。

关于这一切,我有很多不明白的地方。

首先,我dhclient.conf在任何时候都没有改变服务器;它使用默认配置。实际上,它逐字包含以下行:

send host-name "<hostname>"

所以我的第一个问题是,如果配置没有设置为首先发送服务器的真实主机名,它到底是如何知道发送服务器的真实主机名的?

其次,为什么第一个 DHCP 租用(对于旧网络)不包括option host-name,但第二个 DHCP 租用(在新网络上)确实包括它,如果我没有接触任何配置文件?

我所做的只是将原始 VirtualBox 机器导出为 OVF,然后将其导入 XenServer,那么如果它甚至没有配置实际主机名,它是如何通过 DHCP 神奇地配置我的主机名的dhclient.conf

第三:当我运行时hostname,服务器返回fozzie.our.domain,但dhclient.eth0.leases说主机名选项设置为fozzie(无域)。它怎么知道剥离域?

Mik*_*oss 12

好的,经过很长时间在 Internet 上拖网并尝试通读man页面后,我大致了解了发生了什么:

[H]如果配置没有设置为首先发送它,它到底知道发送服务器的真实主机名吗?

显然,send host-name "<hostname>"更具体地说,<hostname>对 Ubuntu 具有特殊意义。它告诉dhclient将您机器的当前主机名发送到 DHCP 服务器。请注意,这是区分大小写的(即,如果您键入<HOSTNAME>,dhclient 会将文字文本发送<HOSTNAME>到 DHCP 服务器)。正如这里这里所报告的,这适用于 Ubuntu Feisty 及更高版本,作为补丁的一部分(具有讽刺意味的是)修复dhclient默认情况下不发送机器主机名的问题。

[W] 为什么第一个 DHCP 租约(对于旧网络)不包括选项主机名,但第二个 DHCP 租约(在新网络上)确实包括它,如果我没有接触任何配置文件?

这似乎是因为并非所有 DHCP 服务器都会将主机名回显给客户端。昨天我们仍然使用基于 Linux 的 ClarkConnect 路由器作为我们的 DHCP 服务器,它将主机名回显给每个客户端。今天我们在该服务器上禁用了 DHCP,并切换到使用我们主域控制器上的内置 DHCP 服务器。我们从 PDC 的 DHCP 租约不包括option host-name任何一个,但它似乎没有任何影响。这些机器在 DNS 中得到更新,它们都可以通过主机名找到彼此。

当我运行时hostname,服务器返回fozzie.our.domain,但 dhclient.eth0.leases说主机名选项设置为fozzie(无域)。它怎么知道剥离域?

这是我没有完全理解 DHCP 的复杂性。我们的 DHCP 服务器被设置为使用我们的域配置我们所有的客户端。我猜 DHCP 服务器足够聪明,可以从客户端发送的主机名中删除域名部分。

任何人都有任何更正或澄清要添加到此答案中?它似乎仍然有点“手工波浪”,所以我不会接受它的原样。