mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-11-05 04:41:20 +00:00
29bc4fe646
This patch brings support to manage sheepdog pools and volumes to libvirt. It uses the "collie" command-line utility that comes with sheepdog for that. A sheepdog pool in libvirt maps to a sheepdog cluster. It needs a host and port to connect to, which in most cases is just going to be the default of localhost on port 7000. A sheepdog volume in libvirt maps to a sheepdog vdi. To create one specify the pool, a name and the capacity. Volumes can also be resized later. In the volume XML the vdi name has to be put into the <target><path>. To use the volume as a disk source for virtual machines specify the vdi name as "name" attribute of the <source>. The host and port information from the pool are specified inside the host tag. <disk type='network'> ... <source protocol="sheepdog" name="vdi_name"> <host name="localhost" port="7000"/> </source> </disk> To work right this patch parses the output of collie, so it relies on the raw output option. There recently was a bug which caused size information to be reported wrong. This is fixed upstream already and will be in the next release. Signed-off-by: Sebastian Wiedenroth <wiedi@frubar.net>
18 lines
375 B
XML
18 lines
375 B
XML
<volume>
|
|
<name>test2</name>
|
|
<key>(null)</key>
|
|
<source>
|
|
</source>
|
|
<capacity unit='bytes'>1024</capacity>
|
|
<allocation unit='bytes'>0</allocation>
|
|
<target>
|
|
<path>sheepdog:test2</path>
|
|
<format type='unknown'/>
|
|
<permissions>
|
|
<mode>0600</mode>
|
|
<owner>4294967295</owner>
|
|
<group>4294967295</group>
|
|
</permissions>
|
|
</target>
|
|
</volume>
|