KVM/Libvirt:如何通过 dnsmasq 将本地 DHCP 租约提供给本地 DNS 服务器

KVM/Libvirt:如何通过 dnsmasq 将本地 DHCP 租约提供给本地 DNS 服务器

在装有 libvirt 3.0.0 的 Ubuntu 17.04 上

我的服务器上定义了多个虚拟网络:

# virsh net-list --all
 Name                 State      Autostart     Persistent
----------------------------------------------------------
 default              active     yes           yes
...
 virtual-mgt-5        active     yes           yes
 ...

当在“virtual-mgt-5”上启动虚拟机时,如果该虚拟机的接口需要 dnsmasq DHCP 服务器来获取其 IP 地址/子网长度,则一旦获取 IP 信息,就无法通过其 FQDN 进行访问。

每个 dnsmasq 实例使用默认值:

systemctl status libvirtd
● libvirtd.service - Virtualization daemon
   Loaded: loaded (/lib/systemd/system/libvirtd.service; enabled; vendor preset: enabled)
   Active: active (running) since Sat 2017-06-10 19:48:58 CEST; 3ms ago
     Docs: man:libvirtd(8)
           http://libvirt.org
 Main PID: 25365 (libvirtd)
    Tasks: 35 (limit: 4915)
   Memory: 27.1M
      CPU: 28ms
   CGroup: /system.slice/libvirtd.service
           ├─22262 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_leaseshelper
           ├─22263 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_leaseshelper
...
           ├─24061 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/virtual-mgt-5.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_leaseshelper
           ├─24062 /usr/sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/virtual-mgt-5.conf --leasefile-ro --dhcp-script=/usr/lib/libvirt/libvirt_leaseshelper
...
           ├─25365 /usr/sbin/libvirtd
           └─25384 /usr/sbin/dnsmasq --help

我不知道选项“--leasefile-ro”是否会妨碍:/etc/libvirt/qemu/networks/virtual-mgt-5.xml 中可能有一个 key=value 来启用此行为,但我在网络 XML 格式

对应XML文件的内容为:

virsh net-edit virtual-mgt-5

<network ipv6='yes'>
  <name>virtual-mgt-5</name>
  <uuid>193ac2c9-13fc-44a6-83f8-477790f1f470</uuid>
  <forward mode='route'/>
  <bridge name='virbr5' stp='on' delay='0'/>
  <mac address='52:54:00:b9:ea:63'/>
  <domain name='actionmystique.net'/>
  <ip address='172.21.0.1' netmask='255.255.0.0'>
    <dhcp>
      <range start='172.21.0.1' end='172.21.255.254'/>
    </dhcp>
  </ip>
  <ip family='ipv6' address='fc21::1' prefix='64'>
    <dhcp>
      <range start='fc21::1' end='fc21::fffe'/>
    </dhcp>
  </ip>
</network>

有什么建议吗?

答案1

Libvirt 提供了两个“nss”模块,可以为客户机启用名称解析。“libvirt”模块将主机名(在网络 XML 中定义)解析为 IP 地址。“libvirt-guest”模块采用略有不同的方法,将客户机域名(而不是主机名)解析为 IP 地址。后者意味着您不需要将主机名添加到网络 XML - 您只需virsh start myguest && ssh myguest

https://wiki.libvirt.org/page/NSS_module

相关内容