From: Mark Huth <mhuth@mvista.com>
To: Jeff Garzik <jgarzik@pobox.com>
Cc: shmulik.hen@intel.com, hadi@cyberus.ca,
Laurent DENIEL <laurent.deniel@thalesatm.com>,
bonding-devel@lists.sourceforge.net, netdev@oss.sgi.com
Subject: Re: [Bonding-devel] Re: [SET 2][PATCH 2/8][bonding] Propagating master's settings toslaves
Date: Mon, 11 Aug 2003 14:27:04 -0700 [thread overview]
Message-ID: <3F380A28.10902@mvista.com> (raw)
In-Reply-To: 3F37C7C3.7070807@pobox.com
Jeff Garzik wrote:
> The answer is, like life, it's a balance.
>
> As a general rule, we do prefer to move all code possible out of the
> Linux kernel. We have even created "initramfs", which for 2.7, will
> be used as a vehicle to move code from the kernel to userspace, that
> previously had to be in the kernel only because it was a task that
> "had to be performed at boot time".
>
> However, one must consider
> (1) does moving code to userspace create any security holes?
> (2) does moving code to userspace dramatically increase the number of
> context switches?
> (3) does moving code to userspace violate some atomicity that being
> inside the kernel guarantees?
>
> In practice, #3 is the showstopper that occurs most often.
>
> This is why I push for a "bonding-utils" package from Jay.... because
> of the general rule above: put it into userspace, where possible.
>
> Jeff
Yes, the answer is balance - the complicated, but non-time critical
things should go into applications. However, we need to retain a basic
ability to perform the failover according to pre-configured rules within
the kernel. Many of our customers use bonding to provide a redundant
network path through the wires and switches for what turn out to be
heavily network dependant applications. In many cases, the systems do
not have a local disk, and everything is obtained via say an NFS mount.
When the MAC breaks, you may not be able to run userland!
In HA systems at this level, guarding against the failure of a redundant
hardware component, we find that it is very helpful for the kernel to be
able to perform a variety of simple, pre-programmed operations without
resort to userland - this keeps the interacting fault domains smaller.
Sure, the decisons about how to configure the behaviors - that is the
policies - belong in applications. But the response to an event which
triggers the actions may well _need_ to be in the kernel.
While the issue may not be so much one of speed - the applications may
well respond in an adequate manner, depending on design and load - the
issue of the amount of the system that must work for recovery is quite
important when trying to push system availabilities into the mythical 5
9's plus region. For an application to run, the system has to be able
to fork and exec, access the file system, allocate memory, etc. Sure,
through careful configuration it is possible to reduce the transient
resources required (run a pre-loaded/locked daemon, make sure the files
are locally cached, etc) then the configuration and testing are
complicated. It worked fine in the lab, because a resource we didn't
realize was critical, never got pushed out of the dcache, for example.
Mark Huth
next prev parent reply other threads:[~2003-08-11 21:27 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-08-09 10:29 [SET 2][PATCH 2/8][bonding] Propagating master's settings to slaves Hen, Shmulik
2003-08-11 2:51 ` jamal
2003-08-11 10:08 ` Shmulik Hen
2003-08-11 13:47 ` jamal
2003-08-11 14:07 ` [Bonding-devel] Re: [SET 2][PATCH 2/8][bonding] Propagating master's settings toslaves Laurent DENIEL
2003-08-11 14:20 ` Shmulik Hen
2003-08-11 14:34 ` jamal
2003-08-11 16:25 ` Shmulik Hen
2003-08-11 16:43 ` Jeff Garzik
2003-08-11 17:31 ` [Bonding-devel] Re: [SET 2][PATCH 2/8][bonding] Propagating master'ssettings toslaves Laurent DENIEL
2003-08-11 17:43 ` Jeff Garzik
2003-08-12 6:31 ` Laurent DENIEL
2003-08-12 12:59 ` jamal
2003-08-12 13:08 ` David S. Miller
2003-08-12 14:10 ` Laurent DENIEL
[not found] ` <1060698412.1063.7.camel@jzny.localdomain>
2003-08-12 14:36 ` Laurent DENIEL
2003-08-12 15:05 ` jamal
2003-08-12 2:32 ` jamal
2003-08-11 21:27 ` Mark Huth [this message]
2003-08-11 21:41 ` [Bonding-devel] Re: [SET 2][PATCH 2/8][bonding] Propagating master's settings toslaves Jay Vosburgh
2003-08-11 23:15 ` [SET 2][PATCH 2/8][bonding] Propagating master's settings to slaves Shmulik Hen
2003-08-11 23:28 ` [Bonding-devel] " Jay Vosburgh
2003-08-12 2:36 ` jamal
2003-08-12 2:33 ` [Bonding-devel] Re: [SET 2][PATCH 2/8][bonding] Propagating master's settings toslaves jamal
2003-08-12 2:31 ` jamal
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=3F380A28.10902@mvista.com \
--to=mhuth@mvista.com \
--cc=bonding-devel@lists.sourceforge.net \
--cc=hadi@cyberus.ca \
--cc=jgarzik@pobox.com \
--cc=laurent.deniel@thalesatm.com \
--cc=netdev@oss.sgi.com \
--cc=shmulik.hen@intel.com \
/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).