Skip to main content

Highly concurrent networking library

Project description

Eventlet is a concurrent networking library for Python that allows you to change how you run your code, not how you write it.

It uses epoll 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.

It's easy to get started using Eventlet, and easy to convert existing
applications to use it. Start off by looking at the `examples`_,
`common design patterns`_, and the list of `basic API primitives`_.

.. _examples: http://eventlet.net/doc/examples.html
.. _common design patterns: http://eventlet.net/doc/design_patterns.html
.. _basic API primitives: http://eventlet.net/doc/basic_usage.html


Quick Example
===============

Here's something you can try right on the command line::

% python
>>> import eventlet
>>> from eventlet.green import urllib2
>>> gt = eventlet.spawn(urllib2.urlopen, 'http://eventlet.net')
>>> gt2 = eventlet.spawn(urllib2.urlopen, 'http://secondlife.com')
>>> gt2.wait()
>>> gt.wait()


Getting Eventlet
==================

The easiest way to get Eventlet is to use pip::

pip install eventlet

The development `tip`_ is available as well::

pip install 'eventlet==dev'

.. _tip: http://bitbucket.org/eventlet/eventlet/get/tip.zip#egg=eventlet-dev


Building the Docs Locally
=========================

To build a complete set of HTML documentation, you must have Sphinx, which can be found at http://sphinx.pocoo.org/ (or installed with `pip install Sphinx`)::

cd doc
make html

The built html files can be found in doc/_build/html afterward.


Twisted
=======

Eventlet had Twisted hub in the past, but community interest to this integration has dropped over time,
now it is not supported, so with apologies for any inconvenience we discontinue Twisted integration.

If you have a project that uses Eventlet with Twisted, your options are:

* use last working release eventlet==0.14
* start a new project with only Twisted hub code, identify and fix problems. As of eventlet 0.13,
`EVENTLET_HUB` environment variable can point to external modules.
* fork Eventlet, revert Twisted removal, identify and fix problems. This work may be merged back into main project.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eventlet-0.16.1.tar.gz (267.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

eventlet-0.16.1-py2.py3-none-any.whl (128.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file eventlet-0.16.1.tar.gz.

File metadata

  • Download URL: eventlet-0.16.1.tar.gz
  • Upload date:
  • Size: 267.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for eventlet-0.16.1.tar.gz
Algorithm Hash digest
SHA256 e8bfd7ba6bbf2223a7cd3b1ffec2f15ab28a2ef65171b57dddd4323c7ac24db7
MD5 58f6e5cd1bcd8ab78e32a2594aa0abad
BLAKE2b-256 284ea15a61d0b244c6d35cca287942b70ce2db467c0fa5722e5e7f68f6dae762

See more details on using hashes here.

File details

Details for the file eventlet-0.16.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for eventlet-0.16.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 71d5a1140ee58c7cb5ee0281d2490975f84ce5ee43f7e14e67007cd61df0b60f
MD5 56c5224d8e016b3f1cbcc6633560196c
BLAKE2b-256 d7d10e625223077bae79072f71c14b6ad17ec4ecb15bc00e65d6d6678e0f770f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page