From: Ingo Molnar <mingo@elte.hu>
To: David Miller <davem@davemloft.net>
Cc: herbert@gondor.apana.org.au, dada1@cosmosbay.com,
netdev@vger.kernel.org, linux-kernel@vger.kernel.org,
a.p.zijlstra@chello.nl
Subject: Re: poor network loopback performance and scalability
Date: Mon, 21 Apr 2008 10:11:03 +0200 [thread overview]
Message-ID: <20080421081103.GA31328@elte.hu> (raw)
In-Reply-To: <20080420.203810.183610437.davem@davemloft.net>
* David Miller <davem@davemloft.net> wrote:
> From: Herbert Xu <herbert@gondor.apana.org.au>
> Date: Mon, 21 Apr 2008 11:24:04 +0800
>
> > Ingo Molnar <mingo@elte.hu> wrote:
> > >
> > > # ifconfig lo mtu 1048576
> >
> > Chiming in late here, but 1048576 can't possibly work with IP which
> > uses a 16-bit quantity as the length header. In fact a quick test
> > seems to indicate that an 1048576 mtu doesn't generate anything
> > bigger than the default 16K mtu.
>
> Right.
>
> To move things forward, we should look into doing something similar to
> what Al Viro suggested, which would be to return an SKB pointer from
> the transmit path and call back into netif_receive_skb() using that.
yep, basically the sk_peer trick that AF_UNIX is already using.
it just seems rather more tricky in the 'real skb' localhost case
because there's no real established trust path we can pass this coupling
of the two sockets over. Netfilter might affect it and deny a localhost
connection. Lifetime rules seem rather tricky as well: either end of the
localhost connection can go away independently so a refcount to the
socket has to be kept. skb->sk might be something to use, but it looks
like a dangerous complication and it would burden the fastpath with an
extra sk reference inc/dec.
... so i'm not implying that any of this is an easy topic to solve (to
me at least :). But fact is that database connections over localhost are
very common on web apps and it is very convenient as well. I use it
myself - AF_UNIX transport is often non-existing in apps and libraries
or is often just an afterthought with limitations - apps tend to
gravitate towards a single API. So i dont think "use AF_UNIX" is an
acceptable answer in this case. I believe we should try to make
localhost transport comparably fast to AF_UNIX.
Ingo
next prev parent reply other threads:[~2008-04-21 8:11 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-02-21 18:51 [RFC,PATCH] loopback: calls netif_receive_skb() instead of netif_rx() Eric Dumazet
2008-02-21 20:14 ` Daniel Lezcano
2008-02-21 23:19 ` Eric Dumazet
2008-02-22 10:19 ` Daniel Lezcano
2008-02-27 2:21 ` David Miller
2008-02-27 7:20 ` Jarek Poplawski
2008-02-27 7:23 ` David Miller
2008-02-27 7:34 ` Jarek Poplawski
2008-03-01 10:26 ` Eric Dumazet
2008-03-04 4:55 ` David Miller
2008-03-04 5:15 ` Stephen Hemminger
2008-03-04 6:27 ` Eric Dumazet
2008-03-23 10:29 ` David Miller
2008-03-23 18:48 ` Eric Dumazet
2008-03-23 19:15 ` Andi Kleen
2008-03-29 1:36 ` David Miller
2008-03-29 8:18 ` Eric Dumazet
2008-03-29 23:54 ` David Miller
2008-03-31 6:38 ` Eric Dumazet
2008-03-31 9:48 ` Ingo Molnar
2008-03-31 10:01 ` Eric Dumazet
2008-03-31 10:12 ` Ingo Molnar
2008-04-01 9:19 ` Eric Dumazet
2008-04-03 14:06 ` Pavel Machek
2008-04-03 16:19 ` Eric Dumazet
2008-03-31 10:08 ` David Miller
2008-03-31 10:44 ` Ingo Molnar
2008-03-31 11:02 ` David Miller
2008-03-31 11:36 ` poor network loopback performance and scalability (was: Re: [RFC,PATCH] loopback: calls netif_receive_skb() instead of netif_rx()) Ingo Molnar
2008-04-21 3:24 ` Herbert Xu
2008-04-21 3:38 ` poor network loopback performance and scalability David Miller
2008-04-21 8:11 ` Ingo Molnar [this message]
2008-04-21 8:16 ` David Miller
2008-04-21 10:19 ` Herbert Xu
2008-04-21 10:22 ` David Miller
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=20080421081103.GA31328@elte.hu \
--to=mingo@elte.hu \
--cc=a.p.zijlstra@chello.nl \
--cc=dada1@cosmosbay.com \
--cc=davem@davemloft.net \
--cc=herbert@gondor.apana.org.au \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.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).