From: Dan Kegel <dkegel@ixiacom.com>
To: linux-kernel@vger.kernel.org
Subject: Re: debate on 700 threads vs asynchronous code
Date: Wed, 29 Jan 2003 13:32:50 -0800 [thread overview]
Message-ID: <3E384882.6020703@ixiacom.com> (raw)
Lee Chin wrote:
> Terje Eggestad <terje.eggestad@scali.com> wrote:
>> Apart from the argument already given on other replies, you should
>> keep in mind that you probably need to give priority to doing receive.
>> THat include your clients, but if you don't you run into the risk of
>> significantly limiting your bandwidth since the send queues around your
>> system fill up.
>>
>> Try doing that with threads.
>>
>> Actually I would recommend the approach c)
>>
>> c) Write an asynchronous system with only 2 or three threads where I
>> manage the connections and keep the state of each connection in a data
>> structure.
>
> Today I do method (C)... but many people seem to say that, hey, pthreads does almost
> just that with a constant memory overhead of remembering the stack per blocking
> thread... so there is no time difference, just that pthreads consumes slightly more
> memory. That is the issue I am trying to get my head around.
The best way to get your head around it is to
benchmark both approaches, and spend some time
refining your implementation of each so you
understand where the bottlenecks are.
> That particular question, no one has answered... in Linux, the scheduler will not go
> around crazy trying to schedule prcosses that are all waiting on IO. NOw the only
> time I see a degrade in threads would be if all are runnable.... in that case a async
> scheme with two threads would let each task run to completion, not thrashing the
> kernel. Is that correct to say?
There are lots of other issues, too.
Talk is cheap and fun, but only coding will give the real answer.
Go forth and code...
- Dan
next reply other threads:[~2003-01-29 21:30 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-01-29 21:32 Dan Kegel [this message]
-- strict thread matches above, loose matches on Subject: below --
2003-01-29 17:26 debate on 700 threads vs asynchronous code Lee Chin
2003-01-30 9:36 ` Terje Eggestad
[not found] <Pine.LNX.4.44.0301241840450.11758-100000@coffee.psychology.mcmaster.ca>
2003-01-25 0:24 ` Dan Kegel
[not found] <Pine.LNX.4.44.0301232144470.8203-100000@coffee.psychology.mcmaster.ca>
2003-01-24 8:21 ` Dan Kegel
2003-01-24 8:26 ` Mark Mielke
2003-01-24 22:53 ` Corey Minyard
2003-01-24 23:21 ` Matti Aarnio
2003-01-24 23:29 ` Randy.Dunlap
2003-01-25 0:11 ` Dan Kegel
[not found] <Pine.LNX.4.44.0301232028480.980-100000@coffee.psychology.mcmaster.ca>
2003-01-24 2:04 ` Dan Kegel
2003-01-24 1:46 Dan Kegel
2003-01-24 0:07 Lee Chin
2003-01-23 23:19 Lee Chin
2003-01-23 23:28 ` Larry McVoy
2003-01-23 23:31 ` Ben Greear
2003-01-27 9:48 ` Terje Eggestad
2003-01-27 21:48 ` Bill Davidsen
2003-01-27 22:08 ` Bill Davidsen
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=3E384882.6020703@ixiacom.com \
--to=dkegel@ixiacom.com \
--cc=linux-kernel@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