[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150224094405.GB19976@gmail.com>
Date: Tue, 24 Feb 2015 10:44:05 +0100
From: Ingo Molnar <mingo@...nel.org>
To: Vojtech Pavlik <vojtech@...e.com>
Cc: Andrew Morton <akpm@...ux-foundation.org>,
Jiri Kosina <jkosina@...e.cz>,
Josh Poimboeuf <jpoimboe@...hat.com>,
Peter Zijlstra <peterz@...radead.org>,
Ingo Molnar <mingo@...hat.com>,
Seth Jennings <sjenning@...hat.com>,
linux-kernel@...r.kernel.org,
Linus Torvalds <torvalds@...ux-foundation.org>,
Arjan van de Ven <arjan@...radead.org>,
Thomas Gleixner <tglx@...utronix.de>,
Peter Zijlstra <a.p.zijlstra@...llo.nl>,
Borislav Petkov <bp@...en8.de>, live-patching@...r.kernel.org
Subject: Re: live kernel upgrades (was: live kernel patching design)
* Vojtech Pavlik <vojtech@...e.com> wrote:
> On Sun, Feb 22, 2015 at 03:01:48PM -0800, Andrew Morton wrote:
>
> > On Sun, 22 Feb 2015 20:13:28 +0100 (CET) Jiri Kosina <jkosina@...e.cz> wrote:
> >
> > > But if you ask the folks who are hungry for live bug
> > > patching, they wouldn't care.
> > >
> > > You mentioned "10 seconds", that's more or less equal
> > > to infinity to them.
> >
> > 10 seconds outage is unacceptable, but we're running
> > our service on a single machine with no failover. Who
> > is doing this??
>
> This is the most common argument that's raised when live
> patching is discussed. "Why do need live patching when we
> have redundancy?"
My argument is that if we start off with a latency of 10
seconds and improve that gradually, it will be good for
everyone with a clear, actionable route for even those who
cannot take a 10 seconds delay today.
Lets see the use cases:
> [...] Examples would be legacy applications which can't
> run in an active-active cluster and need to be restarted
> on failover.
Most clusters (say web frontends) can take a stoppage of a
couple of seconds.
> [...] Or trading systems, where the calculations must be
> strictly serialized and response times are counted in
> tens of microseconds.
All trading systems I'm aware of have daily maintenance
time periods that can afford at minimum of a couple of
seconds of optional maintenance latency: stock trading
systems can be maintained when there's no trading session
(which is many hours), aftermarket or global trading
systems can be maintained when the daily rollover
interested is calculated in a predetermined low activity
period.
> Another usecase is large HPC clusters, where all nodes
> have to run carefully synchronized. Once one gets behind
> in a calculation cycle, others have to wait for the
> results and the efficiency of the whole cluster goes
> down. [...]
I think calculation nodes on large HPC clusters qualify as
the specialized case that I mentioned, where the update
latency could be brought down into the 1 second range.
But I don't think calculation nodes are patched in the
typical case: you might want to patch Internet facing
frontend systems, the rest is left as undisturbed as
possible. So I'm not even sure this is a typical usecase.
In any case, there's no hard limit on how fast such a
kernel upgrade can get in principle, and the folks who care
about that latency will sure help out optimizing it and
many HPC projects are well funded.
> The value of live patching is in near zero disruption.
Latency is a good attribute of a kernel upgrade mechanism,
but it's by far not the only attribute and we should
definitely not design limitations into the approach and
hurt all the other attributes, just to optimize that single
attribute.
I.e. don't make it a single-issue project.
Thanks,
Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists