ArchLinux:KVM: Difference between revisions
mNo edit summary |
No edit summary |
||
Line 7: | Line 7: | ||
= {{Icon24|sitemap}} Installation = | = {{Icon24|sitemap}} Installation = | ||
Before getting started there are a few packages that will be needed to set all of this up. | Before getting started there are a few packages that will be needed to set all of this up. | ||
{{Console|1=pacaur -S qemu-headless qemu-headless-arch-extra vagrant libvirt | {{Console|1=pacaur -S libvirt openssl-1.0 packer-io qemu-headless qemu-headless-arch-extra vagrant}} | ||
== {{Icon|notebook}} vagrant-libvirt == | |||
The libvirt plugin installation for vagrant requires some cleanup first. | |||
{{Console|1=sudo mv /opt/vagrant/embedded/lib/libcurl.so{,.backup}|2=sudo mv /opt/vagrant/embedded/lib/libcurl.so.4{,.backup}|3=sudo mv /opt/vagrant/embedded/lib/libcurl.so.4.4.0{,.backup}|4=sudo mv /opt/vagrant/embedded/lib/pkgconfig/libcurl.pc{,backup} }} | |||
Then build the plugin. | |||
{{Console|1=vagrant plugin install vagrant-libvirt}} | |||
== {{Icon|notebook}} Hugepages == | == {{Icon|notebook}} Hugepages == | ||
Enabling hugepages can improve the performance of virtual machines. First add an entry to the fstab, make sure to first check what the group id of the group {{mono|kvm}} is. | Enabling hugepages can improve the performance of virtual machines. First add an entry to the fstab, make sure to first check what the group id of the group {{mono|kvm}} is. | ||
Line 24: | Line 29: | ||
Again verify the changes. | Again verify the changes. | ||
{{Console|1=grep HugePages_Total /proc/meminfo}} | {{Console|1=grep HugePages_Total /proc/meminfo}} | ||
== {{Icon|notebook}} KVM User == | |||
= | |||
Finally create a user for KVM. | Finally create a user for KVM. | ||
{{Console|1=sudo useradd -g kvm -s /usr/bin/nologin kvm}} | {{Console|1=sudo useradd -g kvm -s /usr/bin/nologin kvm}} |
Revision as of 11:16, 7 August 2017
Introduction
This is a tutorial on how to automate the setup of VMs using KVM on Arch Linux. This tutorial uses QEMU as a back-end for KVM and libvirt, Packer and Vagrant.
This tutorial is meant as a supplement to my OVH: Custom Installation tutorial |
Installation
Before getting started there are a few packages that will be needed to set all of this up.
# pacaur -S libvirt openssl-1.0 packer-io qemu-headless qemu-headless-arch-extra vagrant |
vagrant-libvirt
The libvirt plugin installation for vagrant requires some cleanup first.
# sudo mv /opt/vagrant/embedded/lib/libcurl.so{,.backup} # sudo mv /opt/vagrant/embedded/lib/libcurl.so.4{,.backup} # sudo mv /opt/vagrant/embedded/lib/libcurl.so.4.4.0{,.backup} # sudo mv /opt/vagrant/embedded/lib/pkgconfig/libcurl.pc{,backup} |
Then build the plugin.
# vagrant plugin install vagrant-libvirt |
Hugepages
Enabling hugepages can improve the performance of virtual machines. First add an entry to the fstab, make sure to first check what the group id of the group kvm is.
# grep kvm /etc/group # sudoedit /etc/fstab |
hugetlbfs /dev/hugepages hugetlbfs mode=1770,gid=999 0 0 |
Instead of rebooting, remount instead.
# sudo umount /dev/hugepages # mount /dev/hugepages |
This can then be verified.
# sudo mount | grep huge # ls -FalG /dev/ | grep huge |
Now to set the number of hugepages to use. For this one has to do a bit of math, for each gigabyte of the system RAM that you want to use for VMs you divide the size in megabytes by two.
On my setup I will dedicated 12GB out of the 16GB of system RAM to VMs. This means (12 * 1024) / 2 or 6144 |
Set the number of hugepages.
# echo 6144 | sudo tee /proc/sys/vm/nr_hugepages |
Also set this permanently by adding a file to /etc/sysctl.d.
vm.nr_hugepages = 6144 |
Again verify the changes.
# grep HugePages_Total /proc/meminfo |
KVM User
Finally create a user for KVM.
# sudo useradd -g kvm -s /usr/bin/nologin kvm |
Then modify the libvirt QEMU config to reflect this.
user = "kvm" group = "kvm" |