[MUD-Dev] Sockets
Chris Gray
cg at ami-cg.GraySage.Edmonton.AB.CA
Sun May 9 10:43:34 CEST 1999
[Petri Virkkula:]
> I prefer the commands per a second performance measurement,
> because that number tells more directly how many players can
> be supported by a system.
I would tend to agree. My belief is that your example numbers are weighted
the wrong way, however. I could see it possible for a lightly loaded
multi-threaded system to respond to a single request faster than a
single-threaded system, but that the single-threaded system, having less
overhead, could respond to more requests per second.
> Chris> to say "multi-processor machines"? One could perhaps imagine how a good
> Chris> threaded implementation of something could perform better a poor
> Chris> non-threaded implementation, but I don't think that's what you mean.
>
> Actually there aren't many "single-procesor" machines in the
> market today (neither so many SMP machines however). Many
> (most?) disks for example have their own processors, thus a
> PC could be said to be a "multi-processor" machine. However
> the term "multi-processor" usually refers to SMP.
I was of course referring to the usual definition of "multi-processor"
as a single computer having multiple normal processors used for doing
whatever user work is thrown at them. Typically SMP (Symmetric Multi-
Processors).
I should perhaps expand on what I'm getting at here. Everyone should agree
that the use of threads on a given system introduces more overhead to
that system because of the need for thread switching, if nothing else.
However, the design of some operating system interfaces may be such that
maximum performance can only be obtained by using multiple threads.
Earlier discussions of the cost of large select or poll calls is an
example of some overheads that may be reduced by having multiple outstanding
calls.
The WIN32 interface in particular is one which essentially forces the
programmer to use multiple threads. Consider the "asynchronous I/O"
features available. You can use their completion routines stuff, but they
aren't really asynchronous because they are only triggered when some
I/O related system call completes (e.g. a poll). You can use their
interface which sends a message on call completion, but for that you
have to have an active window, which is something a MUD server (or http
server or ftp server, etc.) is not likely to want. I'm guessing that
this silliness (sending messages to a window, rather than to an
arbitrary message port) is a historical thing. Lastly, you can use the
"overlapped I/O" features, where an event handle becomes signalled when
the operation completes. Here, you must have something (i.e. a thread)
that is waiting for a bunch of such handles to be ready. The call used
for that, WaitForMultipleObjects, has a fixed, hard limit of 64 handles
that it can wait on. If you want more than that, you have to either
start polling (ugh!) or have multiple threads, each waiting for groups
of handles. So, I agree, that if you are programming under the WIN32
API, you will get better performance by using threads than if you
didn't, but *that is a result of the nature of the API, rather than any
inherent advantage of threads*.
Threads are a tool which can be used to restructure your program into a
style that can be easier to read. They do so at the expense of a little
extra overhead. This is just like using C++ classes with virtual functions
to similarly restructure your program, at a small expense.
--
Don't design inefficiency in - it'll happen in the implementation.
Chris Gray cg at ami-cg.GraySage.Edmonton.AB.CA
http://www.GraySage.Edmonton.AB.CA/cg/
_______________________________________________
MUD-Dev maillist - MUD-Dev at kanga.nu
http://www.kanga.nu/lists/listinfo/mud-dev
More information about the mud-dev-archive
mailing list