mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-03-07 17:28:15 +00:00
conf: Add support for blkiotune group_name option
Modify _virDomainBlockIoTuneInfo and rng schema to support the group_name option for iotune throttling. Document the new value. Signed-off-by: John Ferlan <jferlan@redhat.com>
This commit is contained in:
parent
c53bd25b13
commit
32d99cb772
@ -2622,6 +2622,17 @@
|
|||||||
<span class="since">Throughput limits since 1.2.11 and QEMU 1.7</span>
|
<span class="since">Throughput limits since 1.2.11 and QEMU 1.7</span>
|
||||||
</p>
|
</p>
|
||||||
</dd>
|
</dd>
|
||||||
|
<dt><code>group_name</code></dt>
|
||||||
|
<dd>The optional <code>group_name</code> provides the cability
|
||||||
|
to share I/O throttling quota between multiple drives. This
|
||||||
|
prevents end-users from circumventing a hosting provider's
|
||||||
|
throttling policy by splitting 1 large drive in N small drives
|
||||||
|
and getting N times the normal throttling quota. Any name may
|
||||||
|
be used.
|
||||||
|
<p>
|
||||||
|
<span class="since">group_name since 3.0.0 and QEMU 2.4</span>
|
||||||
|
</p>
|
||||||
|
</dd>
|
||||||
<dt><code>total_bytes_sec_max_length</code></dt>
|
<dt><code>total_bytes_sec_max_length</code></dt>
|
||||||
<dd>The optional <code>total_bytes_sec_max_length</code>
|
<dd>The optional <code>total_bytes_sec_max_length</code>
|
||||||
element is the maximum duration in seconds for the
|
element is the maximum duration in seconds for the
|
||||||
|
@ -4997,6 +4997,11 @@
|
|||||||
<data type="unsignedLong"/>
|
<data type="unsignedLong"/>
|
||||||
</element>
|
</element>
|
||||||
</optional>
|
</optional>
|
||||||
|
<optional>
|
||||||
|
<element name="group_name">
|
||||||
|
<text/>
|
||||||
|
</element>
|
||||||
|
</optional>
|
||||||
<choice>
|
<choice>
|
||||||
<element name="total_bytes_sec_max_length">
|
<element name="total_bytes_sec_max_length">
|
||||||
<data type="unsignedLong"/>
|
<data type="unsignedLong"/>
|
||||||
|
@ -7401,6 +7401,9 @@ virDomainDiskDefIotuneParse(virDomainDiskDefPtr def,
|
|||||||
PARSE_IOTUNE(read_iops_sec_max_length);
|
PARSE_IOTUNE(read_iops_sec_max_length);
|
||||||
PARSE_IOTUNE(write_iops_sec_max_length);
|
PARSE_IOTUNE(write_iops_sec_max_length);
|
||||||
|
|
||||||
|
def->blkdeviotune.group_name =
|
||||||
|
virXPathString("string(./iotune/group_name)", ctxt);
|
||||||
|
|
||||||
if ((def->blkdeviotune.total_bytes_sec &&
|
if ((def->blkdeviotune.total_bytes_sec &&
|
||||||
def->blkdeviotune.read_bytes_sec) ||
|
def->blkdeviotune.read_bytes_sec) ||
|
||||||
(def->blkdeviotune.total_bytes_sec &&
|
(def->blkdeviotune.total_bytes_sec &&
|
||||||
@ -20630,6 +20633,7 @@ virDomainDiskDefFormat(virBufferPtr buf,
|
|||||||
def->blkdeviotune.read_iops_sec_max ||
|
def->blkdeviotune.read_iops_sec_max ||
|
||||||
def->blkdeviotune.write_iops_sec_max ||
|
def->blkdeviotune.write_iops_sec_max ||
|
||||||
def->blkdeviotune.size_iops_sec ||
|
def->blkdeviotune.size_iops_sec ||
|
||||||
|
def->blkdeviotune.group_name ||
|
||||||
def->blkdeviotune.total_bytes_sec_max_length ||
|
def->blkdeviotune.total_bytes_sec_max_length ||
|
||||||
def->blkdeviotune.read_bytes_sec_max_length ||
|
def->blkdeviotune.read_bytes_sec_max_length ||
|
||||||
def->blkdeviotune.write_bytes_sec_max_length ||
|
def->blkdeviotune.write_bytes_sec_max_length ||
|
||||||
@ -20658,6 +20662,11 @@ virDomainDiskDefFormat(virBufferPtr buf,
|
|||||||
def->blkdeviotune.size_iops_sec);
|
def->blkdeviotune.size_iops_sec);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (def->blkdeviotune.group_name) {
|
||||||
|
virBufferEscapeString(buf, "<group_name>%s</group_name>\n",
|
||||||
|
def->blkdeviotune.group_name);
|
||||||
|
}
|
||||||
|
|
||||||
FORMAT_IOTUNE(total_bytes_sec_max_length);
|
FORMAT_IOTUNE(total_bytes_sec_max_length);
|
||||||
FORMAT_IOTUNE(read_bytes_sec_max_length);
|
FORMAT_IOTUNE(read_bytes_sec_max_length);
|
||||||
FORMAT_IOTUNE(write_bytes_sec_max_length);
|
FORMAT_IOTUNE(write_bytes_sec_max_length);
|
||||||
|
@ -0,0 +1,61 @@
|
|||||||
|
<domain type='qemu'>
|
||||||
|
<name>QEMUGuest1</name>
|
||||||
|
<uuid>c7a5fdbd-edaf-9455-926a-d65c16db1809</uuid>
|
||||||
|
<memory unit='KiB'>219100</memory>
|
||||||
|
<currentMemory unit='KiB'>219100</currentMemory>
|
||||||
|
<vcpu placement='static'>1</vcpu>
|
||||||
|
<os>
|
||||||
|
<type arch='i686' machine='pc'>hvm</type>
|
||||||
|
<boot dev='hd'/>
|
||||||
|
</os>
|
||||||
|
<clock offset='utc'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>destroy</on_crash>
|
||||||
|
<devices>
|
||||||
|
<emulator>/usr/bin/qemu</emulator>
|
||||||
|
<disk type='block' device='disk'>
|
||||||
|
<driver name='qemu' type='qcow2' cache='none'/>
|
||||||
|
<source dev='/dev/HostVG/QEMUGuest1'/>
|
||||||
|
<target dev='hda' bus='ide'/>
|
||||||
|
<iotune>
|
||||||
|
<total_bytes_sec>5000</total_bytes_sec>
|
||||||
|
<total_iops_sec>6000</total_iops_sec>
|
||||||
|
<total_bytes_sec_max>10000</total_bytes_sec_max>
|
||||||
|
<total_iops_sec_max>11000</total_iops_sec_max>
|
||||||
|
<group_name>libvirt_iotune_group1</group_name>
|
||||||
|
</iotune>
|
||||||
|
<address type='drive' controller='0' bus='0' target='0' unit='0'/>
|
||||||
|
</disk>
|
||||||
|
<disk type='block' device='disk'>
|
||||||
|
<driver name='qemu' type='qcow2' cache='none'/>
|
||||||
|
<source dev='/dev/HostVG/QEMUGuest2'/>
|
||||||
|
<target dev='hdb' bus='ide'/>
|
||||||
|
<iotune>
|
||||||
|
<read_bytes_sec>5000</read_bytes_sec>
|
||||||
|
<write_bytes_sec>5500</write_bytes_sec>
|
||||||
|
<read_iops_sec>3500</read_iops_sec>
|
||||||
|
<write_iops_sec>4000</write_iops_sec>
|
||||||
|
<read_bytes_sec_max>6000</read_bytes_sec_max>
|
||||||
|
<write_bytes_sec_max>6500</write_bytes_sec_max>
|
||||||
|
<read_iops_sec_max>7000</read_iops_sec_max>
|
||||||
|
<write_iops_sec_max>7500</write_iops_sec_max>
|
||||||
|
<size_iops_sec>2000</size_iops_sec>
|
||||||
|
<group_name>libvirt_iotune_group2</group_name>
|
||||||
|
</iotune>
|
||||||
|
<address type='drive' controller='0' bus='0' target='0' unit='1'/>
|
||||||
|
</disk>
|
||||||
|
<controller type='usb' index='0'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/>
|
||||||
|
</controller>
|
||||||
|
<controller type='ide' index='0'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/>
|
||||||
|
</controller>
|
||||||
|
<controller type='pci' index='0' model='pci-root'/>
|
||||||
|
<input type='mouse' bus='ps2'/>
|
||||||
|
<input type='keyboard' bus='ps2'/>
|
||||||
|
<memballoon model='virtio'>
|
||||||
|
<address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
|
||||||
|
</memballoon>
|
||||||
|
</devices>
|
||||||
|
</domain>
|
@ -0,0 +1 @@
|
|||||||
|
../qemuxml2argvdata/qemuxml2argv-blkdeviotune-group-num.xml
|
@ -611,6 +611,7 @@ mymain(void)
|
|||||||
DO_TEST("usb-redir-filter-version", NONE);
|
DO_TEST("usb-redir-filter-version", NONE);
|
||||||
DO_TEST("blkdeviotune", NONE);
|
DO_TEST("blkdeviotune", NONE);
|
||||||
DO_TEST("blkdeviotune-max", NONE);
|
DO_TEST("blkdeviotune-max", NONE);
|
||||||
|
DO_TEST("blkdeviotune-group-num", NONE);
|
||||||
DO_TEST("blkdeviotune-max-length", NONE);
|
DO_TEST("blkdeviotune-max-length", NONE);
|
||||||
DO_TEST("controller-usb-order", NONE);
|
DO_TEST("controller-usb-order", NONE);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user