Basic KVM operations: Difference between revisions

From Newroco Tech Docs
Jump to navigationJump to search
 
(39 intermediate revisions by 6 users not shown)
Line 13: Line 13:
  # sudo virsh list --all
  # sudo virsh list --all


== Start a VM ==
== Start, stop, reboot a VM ==
 
'''Start'''


You can list the VMs first, then:
You can list the VMs first, then:
Line 19: Line 21:
  # sudo virsh start <name of your vm>
  # sudo virsh start <name of your vm>


== Shutdown a VM properly ==
'''Shutdown '''


Note: this require the VM to have support for ACPI - at the moment it doesn't seem to work with windows VMs (seems OK to me- Jo).
Note: this require the VM to have support for ACPI - at the moment it doesn't seem to work with windows VMs (seems OK to me- Jo).
Line 25: Line 27:
  # sudo virsh shutdown <name of the vm>
  # sudo virsh shutdown <name of the vm>


== Shutdown a VM ==
 
'''Reboot '''
 
# virsh reboot <name of the vm>
 
'''Destroy'''


Same thing as taking the plug off. Use with care.
Same thing as taking the plug off. Use with care.


  # sudo virsh destroy <name of the vm>
  # sudo virsh destroy <name of the vm>
== Guest start on boot ( Autostart ) ==
<pre>
sudo virsh autostart $VM_ID
or
sudo virsh autostart --disable $VM_ID
</pre>


== Delete a VM ==
== Delete a VM ==


THIS REMOVES A VM. NO RESTORE POSSIBLE. PLEASE USE WITH SPECIAL CARE.
THIS REMOVES A VM. NO RESTORE POSSIBLE. PLEASE USE WITH SPECIAL CARE.
<pre>
sudo virsh shutdown <name of the vm>
sudo virsh undefine <name of the vm>
sudo rm -rf /var/lib/kvm/<name of the vm>
</pre>
Remove from salt
<pre>
sudo salt-key -L | grep <VM NAME>
sudo salt-key -d <FULL VM NAME>
</pre>
Remove etc/hosts # just for newroco server
<pre>
vi /etc/hosts
# find the VM and delete the name and ip
</pre>


# sudo virsh shutdown <name of the vm>
Remove From zabbix
# sudo virsh undefine <name of the vm>
<pre>
# sudo rm -rf /var/lib/kvm/<name of the vm>
Search for <VM NAME> and them click on delete
</pre>


==Back up a VM==
==Back up a VM==
Line 46: Line 79:


==Copy or move a VM to another host==
==Copy or move a VM to another host==
 
Copy the VM image to remote server in /tmp dir (make sure the VM is shutdown):
* Using scp, we find that a qcow2 disk will expand to its full allocated size when moved or copied to another host (eg a 20gb VM may only take up 5gb of actual disk space, but when copied it takes up the full 20gb)
 
* Eduardo found a solution using rsync. Example:
  rsync /var/lib/kvm/vanilla_templates/w2k3-vanilla3/w2k3-vanilla3.qcow2 ecoria@leibniz.goo.thehumanjourney.net:/home/ecoria/test/
 
===Second method===
In case you have some permission problem you could use this method. Copy the VM image to remote server in /tmp dir:
<pre>
<pre>
rsync /var/lib/kvm/<vm-name>/<vm-image> <remote-server-ip>:/tmp/
rsync /var/lib/kvm/<vm-name>/<vm-image> <remote-server-ip>:/tmp/
Line 73: Line 99:
virsh define /etc/libvirt/qemu/<vm-name>.xml
virsh define /etc/libvirt/qemu/<vm-name>.xml
virsh start <vm-name>
virsh start <vm-name>
virsh autostart <vm-name>
</pre>
</pre>


Line 90: Line 117:
virsh start newname
virsh start newname
</pre>
</pre>
or use
# virsh domrename $OLD_NAME $NEW_NAME
ssh to VM and follow the steps from here: [[changing the hostname]]
ssh to VM and follow the steps from here: [[changing the hostname]]


   
steps from salt minion need to be followed as well : [https://docswiki.newro.co/index.php/SaltStack_SSH#Renaming_a_minion salt]
 
Additional steps delete it from zabbix , rename on the wiki if applicable , CAS changes and url name
 
== Resizing Memory With Script ==
<pre>
VM_ID="my_vm_id"
NEW_AMOUNT="4000"
 
EDITOR='sed -i "s;[0-9]*</currentMemory>;$NEW_AMOUNT</currentMemory>;"' virsh edit $VM_ID
EDITOR='sed -i "s;[0-9]*</memory>;$NEW_AMOUNT</memory>;"' virsh edit $VM_ID
 
sudo virsh shutdown $VM_ID
sudo virsh start $VM_ID
</pre>
 
== Useful Tools ==
 
'''Install tools'''
 
apt-get -y install libguestfs-tools virt-top
 
'''"ls" List a directory in a virtual machine.'''
  # virt-ls -l -d ubuntu /root
 
'''"cat" Display content of a file in a virtual machine.'''
# virt-cat -d ubuntu /etc/network/interfaces
 
 
'''Edit a file in a virtual machine.'''
# virt-edit -d ubuntu /etc/netplan/01-netcfg.yaml
 
'''Edit a file in a virtual machine image.'''
# virt-edit -a /path/to/image.qcow2 /home/user/.bash_history
 
'''Display disk usage in a virtual machine.'''
# virt-df -h -d ubuntu
 
'''Display partition table in a virtual machine (helps a lot when growing a windows VM disk)'''
<pre>#virt-filesystems -a vm-image.qcow2 -l
 
Name      Type        VFS  Label            Size        Parent
/dev/sda1  filesystem  ntfs  System Reserved  104857600    -
/dev/sda2  filesystem  ntfs  -                53030682624  -
/dev/sda3  filesystem  ntfs  -                548405248    -</pre>
 
'''Mount a disk of a virtual machine''' 
# guestmount -d ubuntu -i /mnt
# ll /mnt
 
'''Display the status of virtual machines'''
# virt-top
 
==VM-disk deleted - resolution==
==VM-disk deleted - resolution==


Line 120: Line 203:
Test the copied file with an dummy-VM before shutdown the original VM!
Test the copied file with an dummy-VM before shutdown the original VM!


== List all the VMs with the autostart option activated ==
# sudo virsh list --autostart


[[Category:KVM]]
[[Category:KVM]]


==Snapshoot operations==
==Snapshoot operations==
 
===With virsh===
'''Create snapshoot'''
'''Create snapshoot'''
<pre>
<pre>
virsh shutdown vm_name
virsh shutdown vm_name
virsh snapshot-create-as --domain vm_name \
virsh snapshot-create-as --domain vm_name --name "snapshot_name" --description "Snapshot"
--name "snapshot_name" \
--description "Snapshpot"
</pre>
</pre>
'''Restore snapshoot'''
'''Restore snapshoot'''
<pre>
<pre>
virsh snapshot-list --domain vm_name
virsh snapshot-list --domain vm_name
virsh snapshot-revert --domain vm_name snapshot_name
virsh snapshot-revert --domain vm_name --snapshotname snapshot_name
</pre>
</pre>
'''Delete snapshoot'''
'''Delete snapshoot'''
Line 141: Line 226:
virsh snapshot-delete --domain vm_name --snapshotname snapshot_name_to_be_deleted
virsh snapshot-delete --domain vm_name --snapshotname snapshot_name_to_be_deleted
</pre>
</pre>
===With qemu-img===
This is helpful when the VM was migrated between hosts and snapshots definition was not copied/defined as well
List snapshots
<pre>qemu-img info vm-disk.qcow2</pre>
Delete snapshot
<pre> qemu-img snapshot -d snapshot-name vm-disk.qcow2</pre>


==Adding a disk to VM==
==Adding a disk to VM==
Line 146: Line 240:
<pre>qemu-img create -f qcow2 /path/to/image.qcow2 10G</pre>
<pre>qemu-img create -f qcow2 /path/to/image.qcow2 10G</pre>


Attach the disk to the VM (check before if vda is used; if yes use vdb, vdc, etc.)
Attach the disk to the VM (check before if vda is used; if yes use vdb, vdc, etc.). Make sure to provide the full path to the image.
<pre>virsh vm-name shutdown
<pre>virsh shutdown vm-name
virsh attach-disk vm-name --source /path/to/image.qcow2 --target vda --persistent
virsh attach-disk vm-name --source /path/to/image.qcow2 vdb --driver qemu --subdriver qcow2 --targetbus virtio --persistent</pre>
virsh start vm-name</pre>
 
Before starting the VM check that the disk attached as qcow2 and not another type like raw.
<pre>#virsh edit vm-name
 
<disk type='file' device='disk'>
  <driver name='qemu' type='qcow2'/>
  <source file='/var/lib/kvm/ourbus-nc/ourbus-ncstorage1.qcow2'/>
  <target dev='vda' bus='virtio'/>
  <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0'/>
</disk>
</pre>
 
If type is not qcow2 change it and start the VM.
<pre>virsh start vm-name</pre>


On the VM, check disk ''vda'' has been attached
On the VM, check disk ''vda'' has been attached
Line 158: Line 265:
<pre>parted /dev/vda</pre>
<pre>parted /dev/vda</pre>


If it shows that the disk size is only a few KB, it's an error and it can be resolved by converting the image, detach the image and attach the converted one
If parted throws a warning that the disk size is only a few KB, there is a problem with the disk. In this case go back and investigate, otherwise go ahead and create the partition.
<pre>qemu-img convert -O qcow2 input-image.qcow2 output-image.qcow2</pre>


Format it
Format it
Line 165: Line 271:


If the disk will be used for data storage then reduce the space reserved for root operations
If the disk will be used for data storage then reduce the space reserved for root operations
</pre>tune2fs -m 1 /dev/vda1</pre>
<pre>tune2fs -m 1 /dev/vda1</pre>


Find the UUID of the partition (the groups of numbers/letters before the arrow -> )
Find the UUID of the partition (the groups of numbers/letters before the arrow -> )
Line 176: Line 282:
Append a line to /etc/fstab so your mount can survive a reboot
Append a line to /etc/fstab so your mount can survive a reboot
<pre>UUID=youruuid      /path/to/mymountpoint ext4    defaults        0      0</pre>
<pre>UUID=youruuid      /path/to/mymountpoint ext4    defaults        0      0</pre>
==Detach disk from a VM==
<pre>virsh detach-disk vm-name vda --config</pre>


==Converting==
==Converting==
Line 197: Line 306:
<pre>
<pre>
qemu-img convert -O raw from.qcow2 to.raw
qemu-img convert -O raw from.qcow2 to.raw
</pre>
==List OS suported variants bt virt-install==
When creating a guest with virt-install you need to specify the --os-variant. To get a list of acceptable values (on Ubuntu 16.04), install the libosinfo-bin package before running the command below:
# osinfo-query os
==Reset and set the root password of a certain VM==
First shutdown the VM:
<pre>virsh shutdown <vm_name></pre>
Secondly get the path of the image:
<pre>virsh dumpxml <vm_name> | grep 'source file'</pre>
Afterwards set the root password:
<pre> virt-customize -a <path_of_image> --root-password password:NewRootUserPasswordHere --uninstall cloud-init</pre>
== Enable Virsh Console Access For KVM Guests ==
In order to use VM console access (if it runs out of internet access, for example), the following commands must be run on each guest.
<pre>
systemctl enable serial-getty@ttyS0.service
systemctl start serial-getty@ttyS0.service
</pre>
After running the two commands we can easily connect from the main host using the command:
<pre>
sudo virsh console --domain <vm_name>
</pre>
</pre>

Latest revision as of 13:10, 6 August 2024

SEE ALSO!

List all the VMs, and see which ones are running

# sudo virsh list --all

Start, stop, reboot a VM

Start

You can list the VMs first, then:

# sudo virsh start <name of your vm>

Shutdown

Note: this require the VM to have support for ACPI - at the moment it doesn't seem to work with windows VMs (seems OK to me- Jo).

# sudo virsh shutdown <name of the vm>


Reboot

# virsh reboot <name of the vm>

Destroy

Same thing as taking the plug off. Use with care.

# sudo virsh destroy <name of the vm>

Guest start on boot ( Autostart )

sudo virsh autostart $VM_ID
or
sudo virsh autostart --disable $VM_ID

Delete a VM

THIS REMOVES A VM. NO RESTORE POSSIBLE. PLEASE USE WITH SPECIAL CARE.

sudo virsh shutdown <name of the vm>
sudo virsh undefine <name of the vm>
sudo rm -rf /var/lib/kvm/<name of the vm>

Remove from salt

sudo salt-key -L | grep <VM NAME> 
sudo salt-key -d <FULL VM NAME>

Remove etc/hosts # just for newroco server

vi /etc/hosts
# find the VM and delete the name and ip

Remove From zabbix

Search for <VM NAME> and them click on delete

Back up a VM

After shutting down:

# cd /var/lib/kvm
# cp -R <name of the vm> /to/safe/place

Copy or move a VM to another host

Copy the VM image to remote server in /tmp dir (make sure the VM is shutdown):

rsync /var/lib/kvm/<vm-name>/<vm-image> <remote-server-ip>:/tmp/

On the remote server create a dir for the VM and copy it from /tmp to that dir:

mkdir /var/lib/kvm/<vm-name>
mv /tmp/<vm-image> /var/lib/kvm/<vm-name>/

Now you also need the xml file for that VM. Since it is just text you can copy it, create a file on remote server and paste it there. The xml file is found in this dir:

/etc/libvirt/qemu

After you copied the VM image and xml file you can define and start it:

virsh define /etc/libvirt/qemu/<vm-name>.xml
virsh start <vm-name>
virsh autostart <vm-name>

Rename a VM

Shutdown the VM, dump the xml file and edit it.

virsh shutdown oldname
virsh dumpxml oldname > /etc/libvirt/qemu/newname.xml
vi /etc/libvirt/qemu/newname.xml

In newname.xml change "<name>oldname</name>" to "<name>newname</name>" and "

" to "

". Undefine the VM and define the new one.

virsh undefine oldname
mv /var/lib/kvm/oldname /var/lib/kvm/newname
virsh define /etc/libvirt/qemu/newname.xml
virsh start newname

or use

# virsh domrename $OLD_NAME $NEW_NAME

ssh to VM and follow the steps from here: changing the hostname

steps from salt minion need to be followed as well : salt

Additional steps delete it from zabbix , rename on the wiki if applicable , CAS changes and url name

Resizing Memory With Script

VM_ID="my_vm_id"
NEW_AMOUNT="4000"

EDITOR='sed -i "s;[0-9]*</currentMemory>;$NEW_AMOUNT</currentMemory>;"' virsh edit $VM_ID
EDITOR='sed -i "s;[0-9]*</memory>;$NEW_AMOUNT</memory>;"' virsh edit $VM_ID

sudo virsh shutdown $VM_ID
sudo virsh start $VM_ID

Useful Tools

Install tools

apt-get -y install libguestfs-tools virt-top

"ls" List a directory in a virtual machine.

# virt-ls -l -d ubuntu /root 

"cat" Display content of a file in a virtual machine.

# virt-cat -d ubuntu /etc/network/interfaces 


Edit a file in a virtual machine.

# virt-edit -d ubuntu /etc/netplan/01-netcfg.yaml

Edit a file in a virtual machine image.

# virt-edit -a /path/to/image.qcow2 /home/user/.bash_history

Display disk usage in a virtual machine.

# virt-df -h -d ubuntu

Display partition table in a virtual machine (helps a lot when growing a windows VM disk)

#virt-filesystems -a vm-image.qcow2 -l

Name       Type        VFS   Label            Size         Parent
/dev/sda1  filesystem  ntfs  System Reserved  104857600    -
/dev/sda2  filesystem  ntfs  -                53030682624  -
/dev/sda3  filesystem  ntfs  -                548405248    -

Mount a disk of a virtual machine

# guestmount -d ubuntu -i /mnt 
# ll /mnt

Display the status of virtual machines

# virt-top

VM-disk deleted - resolution

Solution 1

# lsof | grep 101
...
kvm       3649       root   18u      REG              253,2 2147483648     524290  (deleted)/var/lib/vz/images/101/vm-101-disk-1.raw
...

Important is the pid (3649) and the filediscriptor (18) do an copy (before that, it's a good idea to stop important services with open files inside the VM, like databases)

cp /proc/3649/fd/18 /var/lib/vz/images/101/vm-101-disk-1.raw

Voila, the disk-file (of an open-VM!) is copied back.

Solution 2

To conver the image from raw to qcow2

qemu-img convert -p -f qcow2 -O raw /proc/2850/fd/19 vm-100-disk-1.raw

Test the copied file with an dummy-VM before shutdown the original VM!


List all the VMs with the autostart option activated

# sudo virsh list --autostart

Snapshoot operations

With virsh

Create snapshoot

virsh shutdown vm_name
virsh snapshot-create-as --domain vm_name --name "snapshot_name" --description "Snapshot"

Restore snapshoot

virsh snapshot-list --domain vm_name
virsh snapshot-revert --domain vm_name --snapshotname snapshot_name

Delete snapshoot

virsh snapshot-delete --domain vm_name --snapshotname snapshot_name_to_be_deleted

With qemu-img

This is helpful when the VM was migrated between hosts and snapshots definition was not copied/defined as well

List snapshots

qemu-img info vm-disk.qcow2

Delete snapshot

 qemu-img snapshot -d snapshot-name vm-disk.qcow2

Adding a disk to VM

On the host, create an image

qemu-img create -f qcow2 /path/to/image.qcow2 10G

Attach the disk to the VM (check before if vda is used; if yes use vdb, vdc, etc.). Make sure to provide the full path to the image.

virsh shutdown vm-name
virsh attach-disk vm-name --source /path/to/image.qcow2 vdb --driver qemu --subdriver qcow2 --targetbus virtio --persistent

Before starting the VM check that the disk attached as qcow2 and not another type like raw.

#virsh edit vm-name

<disk type='file' device='disk'>
   <driver name='qemu' type='qcow2'/>
   <source file='/var/lib/kvm/ourbus-nc/ourbus-ncstorage1.qcow2'/>
   <target dev='vda' bus='virtio'/>
   <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0'/>
</disk>

If type is not qcow2 change it and start the VM.

virsh start vm-name

On the VM, check disk vda has been attached

# ls -l /dev/disk/by-path/
lrwxrwxrwx 1 root root  9 Oct 23 13:44 virtio-pci-0000:00:05.0 -> ../../vda

Create a partition with parted or other tool

parted /dev/vda

If parted throws a warning that the disk size is only a few KB, there is a problem with the disk. In this case go back and investigate, otherwise go ahead and create the partition.

Format it

mkfs.ext4 /dev/vda1

If the disk will be used for data storage then reduce the space reserved for root operations

tune2fs -m 1 /dev/vda1

Find the UUID of the partition (the groups of numbers/letters before the arrow -> )

#ls -l /dev/disk/by-uuid/
lrwxrwxrwx 1 root root 10 Oct 23 13:45 936de7fd-084f-4456-898f-483341df1cf1 -> ../../vda1

Mount the partition using the UUID

mount /dev/disk/by-uuid/youruuid /path/to/mymountpoint

Append a line to /etc/fstab so your mount can survive a reboot

UUID=youruuid       /path/to/mymountpoint ext4    defaults        0       0

Detach disk from a VM

virsh detach-disk vm-name vda --config

Converting

Info about image

qemu-img info image.vmdk 

From .vdi to .qcow2

qemu-img convert -f vdi -O qcow2 from.vdi to.qcow2

From qcow2 to .vdi

qemu-img convert -O vdi from.qcow2 to.vdi

From .img to .qcow2

qemu-img convert -f raw from.img -O qcow2 to.qcow2

From .qcow2 to .raw

qemu-img convert -O raw from.qcow2 to.raw

List OS suported variants bt virt-install

When creating a guest with virt-install you need to specify the --os-variant. To get a list of acceptable values (on Ubuntu 16.04), install the libosinfo-bin package before running the command below:

# osinfo-query os

Reset and set the root password of a certain VM

First shutdown the VM:

virsh shutdown <vm_name>

Secondly get the path of the image:

virsh dumpxml <vm_name> | grep 'source file'

Afterwards set the root password:

 virt-customize -a <path_of_image> --root-password password:NewRootUserPasswordHere --uninstall cloud-init


Enable Virsh Console Access For KVM Guests

In order to use VM console access (if it runs out of internet access, for example), the following commands must be run on each guest.

systemctl enable serial-getty@ttyS0.service
systemctl start serial-getty@ttyS0.service

After running the two commands we can easily connect from the main host using the command:

sudo virsh console --domain <vm_name>