[Twisted-Python] Degrading under load
data:image/s3,"s3://crabby-images/b6fd9/b6fd92af22a8946fd4af948181f09f8ace2e9686" alt=""
I need to set up a TCP service (on a linux box) that will get something like a few hunderd connections per minute at peak load. For each connection, I do some XML processing, and possibly send a query to another nearby machine and get a respone. Seems to me that twisted should be able to handle that. But what happens when I get the occasional burst of connections, lets say tens of connections within one second? What I need is: o Every client gets a socket connection promptly, so no danger of TCP timeout. o Under medium load, clients will have to wait a bit longer for the response. o Under heavy load, some clients will get a "busy" response (defined in the protocol I am implementing) and immediate socket close. What is the best way to do that in twisted? I envision one of the following architectures: A. Just use twisted in the usual way. Watch twisted's event queue for heavy load. B. Two processes: one to dish out connections and one to queue requests and process them. C. Three processes: one to dish out connections, one to queue requests and watch for load, and one to process the requests. Which of these do I need to use to get the desired effect under load? Or is there some better way? Thanks, Yitz
data:image/s3,"s3://crabby-images/0f80b/0f80b3e5d7ce285c7c4e3dc82c017deb971e275b" alt=""
----- Original Message ----- From: "Yitzchak Gale" <gale@sefer.org> To: <twisted-python@twistedmatrix.com> Sent: Wednesday, March 08, 2006 5:46 AM Subject: [Twisted-Python] Degrading under load --- snip --- premature optimization is just as bad as premature $rhymes_with_optimization. implement all of this in a single process, benchmark under various loads and see if you need to do anything at all. if you do, consider splitting the full handling of a request into separate, cooperative pieces with a deferred/callLater (connection handling and xml processing would be the natural division here). if this is insufficient (eg if the xml processing is sufficiently expensive), perform it in a threadpool. i would only split it off into a completely separate process if you bottleneck on the GIL, which i wouldn't consider likely in your case. -p
participants (2)
-
Paul G
-
Yitzchak Gale