Skip to content

Latest commit

 

History

History
98 lines (73 loc) · 3.37 KB

libvirt-storage-pool.md

File metadata and controls

98 lines (73 loc) · 3.37 KB

kdevops libvirt storage pool considerations

Only read this page if you are using libvirt for virtualization with Vagrant.

Since kdevops uses Vagrant, it is important to understand how Vagrant makes use of storage within libvirt. And the reason it is important is that the way Vagrant uses pool storage is rather stupid, and long term can really be counter productive if you want to scale.

By default, if you are on a bare new system, using Vagrant with libvirt will assume you want to create a "default" libvirt storage pool on the same directory where your Vagrantfile is located! This is insanity. It is pure bananas. This is specially true that today all distributions other than fedora essentially require you to work with root to work with libvirt. On those distros then, if you later want to start guests with libvirt manually, you'd run into a bit of a surprise when you realize what your default libvirt storage pool is.

If you're not sure if you are using libvirt storage pool or have one defined:

virsh pool-list

To figure out the path an existing pool:

virsh pool-dumpxml | grep path

If you don't like this arrangement by all means first destroy guests, and then kill the pool with

virsh pool-destroy <pool-name>
virsh pool-undefine <pool-name>

To destroy guests, you can use something like:

virsh dumpxml <guest-name> | grep desc
cd path-to-test
make destroy # if using kdevops

If the above failed you will have undefine the guest yourself manually:

virsh destroy <guest-name>
virsh undefine <guest-name>
rm -f path-to-all-its-files

Proper storage pool usage for kdevops

We highly recommend a libvirt storage pool set up with kdevops that meets your storage needs. That means think about what drives you want to place your guests on and share data with. This typically just means picking a partition that is fast and has a lot of space.

Then properly name it, something like:

/data1-btrfs/

To help you reflect that that partition was created with BTRFS. Then when configuring kdevops for this setup you are recommended to set two variables with something like the following:

CONFIG_LIBVIRT_STORAGE_POOL_CREATE=y CONFIG_LIBVIRT_STORAGE_POOL_NAME="data1-btrfs" CONFIG_LIBVIRT_STORAGE_POOL_PATH_CUSTOM="/data1-btrfs/libvirt/images"

With this, libvirt will create the storage pool for you with the given name. And the nice thing is that after your first guests comes up, all other further guests which you try to bring up using kdevops on that path /data1-btrfs/ with a new clone of kdevops will lookup your current working directory, and look at all the known libvirt storage pools and paths, and if any storage pool has your base first directory on it, it will be used as the default for the new configuration. So you can be very lazy on bringup on secondary kdevops instances on /data1-btrfs/ after your first full guest is up.

If you are a power user this is very convenient, as it means you can have other partitions, say:

/data2-xfs/

and then create a guest there, use other options like this for its first guest:

CONFIG_LIBVIRT_STORAGE_POOL_CREATE=y CONFIG_LIBVIRT_STORAGE_POOL_NAME="data2-xfs" CONFIG_LIBVIRT_STORAGE_POOL_PATH_CUSTOM="/data2-xfs/libvirt/images"

And then a second configuration of kdevops on any path under /data2-xfs/ will automatically pick up the fact that you very likely want to use the data2-xfs storage pool.