Table des matières
Libvirt
Changer l'emplacement des images disques et images ISO
Par défaut (en tout cas sous ubuntu ;p) les images disque sont sensées être stockées dans le répertoire “/var/lib/libvirt/images/” ce qui est à mon sens tout sauf pratique si vous faites partie des gens qui soit n'allouent pas une partition / de quelques centaines de Go ou encore qui souhaitent utiliser juste un sous répertoire d'une partition deja montée ailleurs.
On peut s'en assurer avec un
virsh pool-dumpxml default
Pour changer le répertoire par défaut des nouvelles images disque, lancer un shell virsh et utiliser les commandes suivantes, par exemple pour utiliser le répertoire /mnt/monGrosTas/VMs_KVM :
virsh # pool-destroy default virsh # pool-undefine default virsh # pool-define-as --name default --type dir --target /mnt/monGrosTas/VMs_KVM virsh # pool-autostart default virsh # pool-start default
Pendant qu'on est la dedans il peut être judicieux de définir un “pool” contenant les images ISO d'installateurs pour faciliter la creation de VMs depuis “virt-manager” :
virsh # pool-define-as --name local-iso --type dir --target /mnt/monGrosTas/ISOs virsh # pool-autostart local-iso virsh # pool-start local-iso
On peut aussi définir un pool accédé directement en NFS (libvirt se chargera tout seul de faire le montage), comme par exemple :
- Créer un fichier /tmp/iso.xml avec le contenu suivant :
<pool type='netfs'> <name>isos</name> <source> <host name="nfs.mondomaine.com"/> <dir path="/srv/iso"/> <format type='nfs'/> </source> <target> <path>/srv/iso</path> </target> </pool>
- Définir le storage-pool associé :
# virsh pool-define /tmp/iso.xml
- Démarrer le pool :
# virsh pool-start isos
- Et lui dire de le redémarrer automatiquement :
# virsh pool-autostart isos
Avoir un clavier francais en accédant à une VM en VNC
Il faut pour cela modifier la configuration de la VM ( “domain” ) , et rajouter à l'intérieur de la balise “graphics” :
keymap='fr'
dpkg-reconfigure console-setup
- Editer la configuration de la VM , par exemple pour la machine nommée “maVM” :
virsh edit maVM
- Ajouter l'option pour obtenir par exemple :
... <graphics type='vnc' port='-1' autoport='yes' listen='127.0.0.1' keymap='fr'/> ...
Il faut bien sur redémarrer la VM proprement :
- se connecter à la VM comme d'habitude, arreter la VM depuis le systeme :
ssh root@maVM root@maVM:~# halt
virsh stop maVM
virsh start maVM
Cette option doit se traduire par la présence dans la commande KVM lancée par libvirt de “-k fr”, vous pouvez vérifier avec un petit “ps aux”.
Configurer libvirt pour autoriser le boot PXE
Le reseau par defaut déclaré dans libvirt ne permet pas le boot réseau, pour le permettre il faut définir un réseau comme suit :
- exporter l'ancien reseau en XML :
# virsh net-dumpxml > /tmp/network.xml
- editer le fichier XML obtenu, et rajouter les balises <tftp> dans <ip> et <bootp> dans <dhcp>. Le fichier obtenu doit ressembler à :
<network> <name>default</name> <uuid>3f52b3a6-fd33-a46a-7d15-67c917fa9cc2</uuid> <forward mode='nat'/> <bridge name='virbr0' stp='on' delay='0' /> <ip address='192.168.122.1' netmask='255.255.255.0'> <tftp root='/mnt/data/tftpboot' /> <dhcp> <range start='192.168.122.2' end='192.168.122.254' /> <bootp file='pxelinux.0' /> </dhcp> </ip> </network>
- réimporter ce nouveau réseau :
# virsh net-destroy default # virsh net-define /tmp/network.xml # virsh net-autostart default # virsh net-start default
- verifier la presence des options passées a dnsmasq, par exemple :
$ ps aux | grep dnsmasq nobody 1739 0.0 0.0 21688 1116 ? S 10:03 0:02 dnsmasq --strict-order --bind-interfaces --pid-file=/var/run/libvirt/network/default.pid --conf-file= --except-interface lo --listen-address 192.168.122.1 --dhcp-range 192.168.122.2,192.168.122.254 --dhcp-lease-max=253 --dhcp-no-override --enable-tftp --tftp-root /mnt/data/tftpboot --dhcp-boot pxelinux.0
noter le “ –enable-tftp –tftp-root /mnt/data/tftpboot –dhcp-boot pxelinux.0”.
# apt-get install kvm-pxe
Assigner toujours la même adresse IP a une VM donnée
Il est possible de demander au dnsmasq utilisé par libvirtd d'assigner toujours la même adresse IP a une VM donnée.
Utilisation dynamique
Dans son infinie bonté la commande virsh net-update a été crée la sous commande net-update qui s'utilise comme dans l'exemple suivant, en remplacant l'adresse MAC, le nom et l'ip selon vos besoins :
# virsh net-update default add ip-dhcp-host \ "<host mac='52:54:00:83:a2:cf' \ name='debianlive' ip='192.168.122.10' />" \ --live --config
ip-dhcp-host ip-dhcp-range (add/delete uniquement, pas de modify) forward-interface (add/delete uniquement) portgroup dns-host dns-txt dns-srv
Ancienne méthode nécessitant de redémarrer le réseau
Pour ce faire, il faut éditer le réseau utilisé (dans mon cas “default”) :
# virsh net-edit default
- dans <network><ip><dhcp> , ajouter une ligne pour chaque hote ressemblant à :
<host mac='52:54:00:83:a2:cf' name='debianlive' ip='192.168.122.10' />
ou vous l'aurez compris, il faut remplacer l'adresse MAC par celle de votre VM, mettre le nom que vous souhaitez, et une adresse IP appartenant au range défini
Vous croyez avoir fini ? que nenni : il faut ensuite redémarrer le réseau (et donc couper le réseau de toutes les VMs ) de libvirt en utilisant les commandes suivantes :
# virsh net-destroy default # virsh net-start default
Exemple de fichier de configuration reseau complet
<network> <name>default</name> <uuid>3f52b3a6-fd33-a46a-7d15-67c917fa9cc2</uuid> <forward mode='nat'/> <bridge name='virbr0' stp='on' delay='0' /> <domain name='kvm.vm'/> <ip address='192.168.122.1' netmask='255.255.255.0'> <tftp root='/mnt/data/tftpboot' /> <dhcp> <range start='192.168.122.100' end='192.168.122.254' /> <host mac='52:54:00:83:a2:cf' name='debianlive' ip='192.168.122.10' /> <host mac='52:54:00:e9:94:16' name='debianunstable64' ip='192.168.122.11' /> <host mac='52:54:00:ef:10:8e' name='xivo' ip='192.168.122.22' /> <bootp file='pxelinux.0' /> </dhcp> </ip> </network>
Utiliser le monde monitor de KVM avec libvirt
Pour bénéficier des commandes monitor (ici info block) de KVM/qemu en passant par libvirt, on peut utiliser, pour la VM ma-machine-virtuelle :
# virsh qemu-monitor-command --hmp ma-machine-virtuelle 'info block'
Utiliser les commandes virsh en tant qu'utilisateur
Vous avez tout bien fait comme il faut en ajoutant vos utilisateurs au groupe libvirt en pensant qu'ils auront le droit de voir/lancer les VMs et vous avez eu raison Cependant à cause d'une conf douteuse, par defaut la conf utilisateur n'est pas la meme que la conf root/systeme par défaut
du coup si le 'virsh list' ne vous renvoie rien lorsque vous le lancez en tant qu'utilisateur simple c'est malheureusement normal.
En root le défaut est “qemu:///system” alors que le défaut concernant un utilisateur est “qemu:///session” ( https://listman.redhat.com/archives/libvirt-users/2015-December/msg00005.html ) , sauf que bien sur chaque utilisateur dispose de sa propre session donc un utilisateur ne peut voir/interagir que sur ses propres VMs … pratique n'est il pas ? ;p
Tout va bien puisque vous êtes ici, deja on va commencer par tester si la commande suivante renvoie bien ce que vous attendez : la liste des VMs completes :
$ virsh --connect qemu:///system list
Et si ca marche juste en lancant la commande suivante on va lui dire d'utiliser cette valeur tout le temps pour cet utilisateur (malheureusement à exécuter pour chaque utilisateur) :
$ echo 'uri_default = "qemu:///system"' >> ~/.config/libvirt/libvirt.conf
Et voila a vous les joies du simple virsh list qui marche enfin comme vous l'attendiez