From: Anthony Liguori <anthony@codemonkey.ws>
To: Gleb Natapov <gleb@redhat.com>
Cc: Paul Brook <paul@codesourcery.com>, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [RESEND][PATCH 0/3] Fix guest time drift under heavy load.
Date: Thu, 06 Nov 2008 09:37:56 -0600 [thread overview]
Message-ID: <49130F54.4060907@codemonkey.ws> (raw)
In-Reply-To: <20081106145142.GA29861@redhat.com>
Gleb Natapov wrote:
> On Thu, Nov 06, 2008 at 08:40:09AM -0600, Anthony Liguori wrote:
>
>
>> Gleb: are you perhaps using a qcow2 file in conjunction with -snapshot?
>>
> I am using qcow2, but without -snapshot.
>
Okay, you would still see this if your qcow2 is relatively small
compared to the possible size it could be.
I totally believe that you could miss ticks from qcow2 metadata writing
even with 100hz clock especially since we're using O_SYNC. A relatively
large write that has to extend the qcow2 file multiple times could
conceivably block the guest for more than 10ms. However, this is a bug
in qcow2 IMHO. Metadata updates should be done asynchronously and if
they did, I bet this problem wouldn't occur. A test against raw should
confirm this.
>
>>> If part of qemu gets swapped out then all bets are off, and you can
>>> easily stall for significant fractions of a second. No amount of host
>>> high resolution time support will help you there.
>>>
>>>
>> Running a steady workload, you aren't going to be partially swapped.
>>
>>
> We want to oversubscribe host as much as possible, and workload will
> vary during a lifetime of the VMs.
>
I understand that we want guest time behave even when we're
overcommitting the host CPU.
However, let's make sure we understand exactly what's going on such that
we know precisely what we're fixing. I believe the file copy benchmark
is going to turn out to no longer produce drift with a raw image. If
that's the case, you'll need to find another benchmark to quantify drift.
I think the best ones are going to be intense host workload (and let's
see how much is needed before we start drifting badly) and high guest
frequencies with hosts that lack high resolution timers. I think with a
high resolution guest and no host overcommit, it should be very
difficult to produce drift regardless of what the guest is doing.
Regards,
Anthony Liguori
> --
> Gleb.
>
next prev parent reply other threads:[~2008-11-06 15:38 UTC|newest]
Thread overview: 49+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-10-29 15:22 [Qemu-devel] [RESEND][PATCH 0/3] Fix guest time drift under heavy load Gleb Natapov
2008-10-29 15:22 ` [Qemu-devel] [PATCH 1/3] Change qemu_set_irq() to return status information Gleb Natapov
2008-10-29 15:22 ` [Qemu-devel] [PATCH 2/3] Fix time drift problem under high load when PIT is in use Gleb Natapov
2008-10-29 15:22 ` [Qemu-devel] [PATCH 3/3] Fix time drift problem under high load when RTC " Gleb Natapov
2008-11-05 12:46 ` Dor Laor
2008-10-31 19:17 ` [Qemu-devel] [RESEND][PATCH 0/3] Fix guest time drift under heavy load Anthony Liguori
2008-11-02 13:04 ` Gleb Natapov
2008-11-05 12:45 ` Dor Laor
2008-11-05 15:48 ` andrzej zaborowski
2008-11-05 16:33 ` Anthony Liguori
2008-11-06 7:16 ` Gleb Natapov
2008-11-06 9:37 ` andrzej zaborowski
2008-11-06 10:08 ` Gleb Natapov
2008-11-06 13:21 ` andrzej zaborowski
2008-11-06 14:18 ` Gleb Natapov
2008-11-06 14:35 ` andrzej zaborowski
2008-11-06 15:04 ` Gleb Natapov
2008-11-06 15:41 ` Anthony Liguori
2008-11-07 23:18 ` andrzej zaborowski
2008-11-08 8:23 ` Gleb Natapov
2008-11-06 13:44 ` Paul Brook
2008-11-05 17:43 ` Gleb Natapov
2008-11-06 17:28 ` David S. Ahern
2008-11-05 16:43 ` Anthony Liguori
2008-11-06 3:55 ` Jamie Lokier
2008-11-06 8:12 ` Gleb Natapov
2008-11-06 14:10 ` Anthony Liguori
2008-11-06 14:24 ` Paul Brook
2008-11-06 14:40 ` Anthony Liguori
2008-11-06 14:51 ` Gleb Natapov
2008-11-06 15:37 ` Anthony Liguori [this message]
2008-11-08 8:36 ` Gleb Natapov
2008-11-08 22:14 ` Dor Laor
2008-11-09 7:40 ` Gleb Natapov
2008-11-09 16:38 ` Anthony Liguori
2008-11-09 21:00 ` Avi Kivity
2008-11-09 16:36 ` Anthony Liguori
2008-11-10 14:37 ` Gleb Natapov
2008-11-10 15:24 ` Anthony Liguori
2008-11-10 15:29 ` Gleb Natapov
2008-11-10 15:46 ` Anthony Liguori
2008-11-10 15:51 ` Gleb Natapov
2008-11-11 14:43 ` Gleb Natapov
2008-11-11 17:26 ` Anthony Liguori
2008-11-11 20:17 ` Anthony Liguori
2008-11-12 11:42 ` Gleb Natapov
2008-11-12 11:54 ` Glauber Costa
2008-11-12 12:38 ` Dor Laor
2008-11-06 3:41 ` Jamie Lokier
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=49130F54.4060907@codemonkey.ws \
--to=anthony@codemonkey.ws \
--cc=gleb@redhat.com \
--cc=paul@codesourcery.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).