| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 | .. _concurrency-eventlet:=========================== Concurrency with Eventlet===========================.. _eventlet-introduction:Introduction============The `Eventlet`_ homepage describes it as;A concurrent networking library for Python that allows you tochange how you run your code, not how you write it.    * It uses `epoll(4)`_ or `libevent`_ for      `highly scalable non-blocking I/O`_.    * `Coroutines`_ ensure that the developer uses a blocking style of      programming that is similar to threading, but provide the benefits of      non-blocking I/O.    * The event dispatch is implicit, which means you can easily use Eventlet      from the Python interpreter, or as a small part of a larger application.Celery supports Eventlet as an alternative execution pool implementation.It is in some cases superior to multiprocessing, but you need to ensureyour tasks do not perform blocking calls, as this will halt allother operations in the worker until the blocking call returns.The multiprocessing pool can take use of multiple processes, but how many isoften limited to a few processes per CPU.  With Eventlet you can efficientlyspawn hundreds, or thousands of green threads.  In an informal test with afeed hub system the Eventlet pool could fetch and process hundreds of feedsevery second, while the multiprocessing pool spent 14 seconds processing 100feeds.  Note that is one of the applications evented I/O is especially goodat (asynchronous HTTP requests).  You may want a mix of both Eventlet andmultiprocessing workers, and route tasks according to compatibility orwhat works best.Enabling Eventlet=================You can enable the Eventlet pool by using the ``-P`` option to:program:`celeryd`::    $ celeryd -P eventlet -c 1000.. _eventlet-examples:Examples========See the `Eventlet examples`_ directory in the Celery distribution forsome examples taking use of Eventlet support... _`Eventlet`: http://eventlet.net.. _`epoll(4)`: http://linux.die.net/man/4/epoll.. _`libevent`: http://monkey.org/~provos/libevent/.. _`highly scalable non-blocking I/O`:    http://en.wikipedia.org/wiki/Asynchronous_I/O#Select.28.2Fpoll.29_loops.. _`Coroutines`: http://en.wikipedia.org/wiki/Coroutine.. _`Eventlet examples`:    https://github.com/celery/celery/tree/master/examples/eventlet
 |