>
> This seems ok for the use case where we just give a domain a few
> iothreads and all the disks will share them.
>
> But if you go for one iothread per disk, creating holes in iothread
> indexes could make sense - we allow unplugging disks from the middle.
>
> I can't think of a case where hotplugging a thread with id=6 would be
> useful if there are only 3 threads.
>
> Maybe there should be separate APIs for adding and deleting threads?
I have to agree here. Separate API for adding and removing (or perhaps
just a parameter to switch?) specific threads is the way to go. Why?
Well this function looks like it was copied from virDomainSetVcpus which
I'm currently planning to replace with specific vcpu hotplug api.
The reasons there are the same as Jan pointed out just translated into
the context of vCPUS. At the point where there is no other mapping or
relationship of belonging the API is fine. This was true for vCPUs in
the pre-NUMA era. With NUMA, (or disks IO executed by iothreads in this
case) you have a relationship where a thread (or vCPU) belongs to a dis
(or NUMA node) and you need to be able to select them individually.
Obviously at this point these changes won't make 1.2.14... Would have
been nice to have all IOThreads changes in one release, but better to
get things right.
I think the following is close, but I'm still stuck on how to handle
deleting a thread in the middle. Compared to the vCPU algorithm - if you
remove a vCPU you're not given the choice of which one to remove. The
last one is removed.
The problem is how to or whether to represent/save the thread_id array
values in the event of a "hole" in the sequence. Sure we could
create/save a bitmap of 'iothreads' count entries in use, but is there a
'max' value for that? Technically there's no restriction to the number
of IOThreads (theoretically there is ;-))
Here's some rough thoughts for an Add and Del API :
* virDomainAddIOThread:
* @domain: a domain object
* @count: the number of IOThread's to add the domain
* @flags: bitwise-OR of virDomainModificationImpact
* virDomainDelIOThread:
* @domain: a domain object
* @iothread_id: the specific IOThread ID value to delete
* @flags: bitwise-OR of virDomainModificationImpact
A "live" domain has 'n' IOThreads in an iothreads array[]. We
"add" to
or "refill" the array and adjust the count of iothreads. The refill
option would be if we delete in the middle of the array.
NB: Deletion will always fail if a disk is assigned to a thread, so
discount that. It would be nice if deletion only allowed deletion off
the end of the array, but that's not guaranteed, so per
When "del"eting entries, things get tricky, especially in the middle. At
the end it's easy... The middle just presents problems which I need to
think about or get some feedback...
Thus... start with 4 threads, live domain:
- Add 'n' threads
- Search live iothreads array for empty entries to refill
- If an entry is found, refill it, reduce 'n' keep going
- If none or we reach array size,
add 'n' to the live and config count
- Del Thr#4
- The live iothreads array entry is zeroed
- The live & config number of threads reduced to 3
- Del Thr#1 (or 2 or 3)
- The live iothreads array entry is zeroed
- The live and config iothreads entry count remains at 4
For an inactive domain with 4 threads
- Add 'n' threads
- Just adjust iothreads array count
- Del 'Thr#4'
- Adjust count to 3
- Del 'Thr#1' (or 2 or 3)
- Fail
OR
- If subsequent threads don't have disks assigned, then threads from
'#' to end are removed. e.g, Del 3 would then remove 3 & 4... Del 2
would remove 2, 3, & 4.
Tough to document, but enforcing that the config always can create
'live' threads of some numbered count without having some sort of hole.
Other bright ideas welcome -
Tks -
John