On Mon, Jan 10, 2000 at 03:20:38PM -0800, Scott Hess wrote:
> I've implemented a rough fix, which is to rfork() processes which I label
> "iothreads" to handle the disk I/O.  The parent process running pthreads
> has a socketpair() to each of the iothreads.  The iothreads wait for
> requests on the socketpair, and since socketpairs can block, pthreads can
> handle them efficiently.  This essentially allows me to turn blocking disk
> I/O calls into non-blocking calls.  Having multiple pending seeks turns out
> to be a huge win for MYSQL, allowing it to scale much better as disks are
> added to the RAID5 array.
> 
> Unfortunately, I'm concerned about using this code in production, because
> it needs a fair amount of cleanup to handle signals and administrative
> functions correctly.  For this reason and others, I'm starting a project to
> move it into the pthreads library itself.  Before I embark on that effort,
> I have a couple questions:
> 
> 1) Does this seem like a reasonable approach?  [It _works_, and well.  But
> it tastes strongly of hack.]

I'm not very fond of this approach to the problem, though it can work, as
you note.  Asynchronous I/O is in my opinion a much cleaner solution.

> 2) Does anyone have suggestions for a solution that will be cleaner and
> won't take man-months to implement?  [Which is the redeeming quality of
> what I've got - it took me two days to zero in on a very workable
> solution.]

Have you tried the linuxthreads port lately?  With linuxthreads, each
thread is an rfork()ed process, which means that blocking on file I/O only
blocks the thread that attempts the I/O.  There are various
advantages/disadvantages between libc_r and linuxthreads, but you may find
linuxthreads to meet your needs at the moment.

> 3) Is anyone working on something I might leverage off of in this area?
> [For instance, a select()-based interface to async I/O?  Or support for
> blocking disk I/O in select() and read()?]

Though not ideal, it seems to me that using asynchronous I/O will work
reasonably well inside libc_r.  If there weren't plans to build a much more
scalable threads library than what we currently have, this modification
would be high on my priority list.

Jason


To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-hackers" in the body of the message

Reply via email to