KVM / Libvirt: como disponibilizar as concessões DHCP locais para o servidor DNS local por meio do dnsmasq

1

No Ubuntu 17.04 com o libvirt 3.0.0

Eu tenho várias redes virtuais definidas no meu servidor:

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

Quando uma máquina virtual é iniciada em "virtual-mgt-5" com uma interface que precisa do servidor DHCP dnsmasq para obter seu endereço IP / comprimento de sub-rede, ela permanece inacessível por meio de seu FQDN.

Os valores padrão são usados para cada instância do 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

Gostaria de saber se a opção "--leasefile-ro" fica no caminho ou não: pode haver um valor key = em /etc/libvirt/qemu/networks/virtual-mgt-5.xml para ativar esse comportamento , mas não consegui encontrá-lo no formato XML da rede .

O conteúdo do arquivo XML correspondente é:

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>

Alguma sugestão?

    
por jean-christophe manciot 13.06.2017 / 11:12

1 resposta

0

O Libvirt fornece dois módulos 'nss' que podem permitir a resolução de nomes para os convidados. O módulo 'libvirt' resolve nomes de host (definidos no XML da rede) para addrs de IP. O módulo 'libvirt-guest' tem uma abordagem um pouco diferente, resolvendo o nome do domínio guest, em vez do hostname, para endereços IP. O último significa que você não precisa adicionar nomes de host ao XML da rede - você pode apenas virsh start myguest && ssh myguest

link

    
por 15.06.2017 / 13:57