Mix Python Twisted with multiprocessing?

Posted on

Question :

Mix Python Twisted with multiprocessing?

I need to write a proxy like program in Python, the work flow is very similar to a web proxy. The program sits in between the client and the server, incept requests sent by the client to the server, process the request, then send it to the original server. Of course the protocol used is a private protocol uses TCP.

To minimize the effort, I want to use Python Twisted to handle the request receiving (the part acts as a server) and resending (the part acts as a client).

To maximum the performance, I want to use python multiprocessing (threading has the GIL limit) to separate the program into three parts (processes). The first process runs Twisted to receive requests, put the request in a queue, and return success immediately to the original client. The second process take request from the queue, process the request further and put it to another queue. The 3rd process take request from the 2nd queue and send it to the original server.

I was a new comer to Python Twisted, I know it is event driven, I also heard it’s better to not mix Twisted with threading or multiprocessing. So I don’t know whether this way is appropriate or is there a more elegant way by just using Twisted?

Asked By: benhengx


Answer #1:

Twisted has its own event-driven way of running subprocesses which is (in my humble, but correct, opinion) better than the multiprocessing module. The core API is spawnProcess, but tools like ampoule provide higher-level wrappers over it.

If you use spawnProcess, you will be able to handle output from subprocesses in the same way you’d handle any other event in Twisted; if you use multiprocessing, you’ll need to develop your own queue-based way of getting output from a subprocess into the Twisted mainloop somehow, since the normal callFromThread API that a thread might use won’t work from another process. Depending on how you call it, it will either try to pickle the reactor, or just use a different non-working reactor in the subprocess; either way it will lose your call forever.

Answered By: Glyph

Answer #2:

ampoule is the first thing I think when reading your question.

It is a simple process pool implementation which uses the AMP protocol to communicate. You can use the deferToAMPProcess function, it’s very easy to use.

Answered By: nosklo

Answer #3:

You can try something like Cooperative Multitasking technique as it’s described there http://us.pycon.org/2010/conference/schedule/event/73/ . It’s simillar to technique as Glyph menitioned and it’s worth a try.

You can try to use ZeroMQ with Twisted but it’s really hard and experimental for now 🙂

Answered By: kkszysiu

Leave a Reply

Your email address will not be published. Required fields are marked *