[virt-tools-list] [RFC PATCH v3 0/7] Guest time sync on snapshot resume
Cole Robinson
crobinso at redhat.com
Tue Dec 17 22:51:21 UTC 2019
On 12/9/19 4:53 PM, Michael Weiser wrote:
> Hello Cole,
>
> this is the third iteration of implementing guest time sync as per
> your suggestions. The only change compared to v2 is in the way the last
> patch blocks the toggled signal.
>
> These patches do:
> * add method _set_time() calling the libvirt setTime API
> * wire it up in resume from paused and saved state as well as revert to
> a snapshot containing a running domain state
> * only run the API if the connection is of type qemu or test
> * only run the API if a guest agent channel is defined for a qemu
> connection
> * wait for the guest agent channel state to become connected, i.e. the
> guest agent coming online inside the guest
> * add global and per-vm option to disable time sync
> * try to fix up some peculiar behaviour of checkable vm window menu
> items
>
Nice work. I pushed the first 4 patches.
> If you drop me some quick pointers how to go about dispatching the set
> time operation to a separate or already existing background thread so it
> doesn't block the UI, I'll be happy to give that a whirl as well. As it
> stands now, the attempts at syncing time cause a five second delay if
> the agent does not come online. It would be nice to avoid that.
>
Does it make the progress dialog spin for 5 seconds, or does it actually
block any interaction with the app? All the actions that you added
_set_time to should be invoked via threads in the UI portions of the
code, if they aren't then that's a bug in itself.
But if you wanted to avoid the sleep spin in _set_time, the way to do it
is to use timeout_add, which will invoke the passed function from the
main UI thread when the timeout is hit. Everywhere you have a
time.sleep(X) in the current code, you'd do
self.timeout_add(X * 1000, self._set_time, args)
In args, you'd pass how many iterations the loop has already done, so
you can track when to kill the timeout loop.
As for for the configuration piece, I'd prefer not to add it at all
unless there's a really good reason. Yes hardcoding timeouts will always
mean we get it wrong in some case, but I don't think this is important
enough to justify 100 lines of code and UI to match, and the testing and
maintenance burden that entails. Plus I just don't expect many people
will ever change the setting unless I'm missing some specific case.
There is possible ways to make it not need a timeout, like watching for
the domain event when the agent is connected. It's probably tricky to
get it right.
Generally I'd rather jack up the timeout and use the timeout_add
behavior to hide it from the UI, then make this configurable.
Thanks,
Cole
More information about the virt-tools-list
mailing list