{{tag>virtualisation libvirt clavier keymap azerty vnc boot PXE reseau VM dnsmasq adresse ip statique dhcp images qcow raw iso}}
====== 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 : isos/srv/iso
* 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'Ne pas éditer le fichier XML de la VM dans /etc/libvirt/qemu/ de la VM directement, ca ne marche pas (en tous cas si la VM est en fonctionnement).Il peut etre nécessaire de configurer le keymap dans la VM, comme par exemple sous ubuntu 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 :
...
...
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 dans et dans . Le fichier obtenu doit ressembler à :default3f52b3a6-fd33-a46a-7d15-67c917fa9cc2Il faut bien sur adapter le parametre root du tftp pour utiliser le repertoire de votre choix comme racine du serveur TFTP.
* 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".
Pour que le boot PXE fonctionne avec kvm, il faut disposer d'un firmware des cartes reseau utilisées dans les VMs gérant le boot PXE. Pour les obtenir, sur ubuntu 11.04 il faut par exemple installer le paquet kvm-pxe :# 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 \
"" \
--live --configEn plus de la sous commande **add**, virsh net-update peu également prendre les sous commandes **delete**, **modify** (certains items uniquement), **add-first** et **add-last**
Cette commande net-update peut s'utiliser avec les items suivants :
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 ====
Attention cette méthode nécessite de redémarrer le réseau géré par libvirt et donc **couper le réseau de toutes les VMs**. Il faudra donc éteindre puis rallumer toutes les VMs pour leur procurer à nouveau du réseau
Pour ce faire, il faut éditer le réseau utilisé (dans mon cas "default") :
* # virsh net-edit default
* dans , ajouter une ligne pour chaque hote ressemblant à : 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
Magie, en activant ceci, vous venez aussi d'activer le fonctionnement du DNS : n'importe quelle VM pourra maintenant résoudre le nom "debianlive"
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 =====
default3f52b3a6-fd33-a46a-7d15-67c917fa9cc2
===== 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