Coroutine-based network library
Project description
gevent
gevent is a coroutine -based Python networking library that uses greenlet to provide a high-level synchronous API on top of the libev or libuv event loop.
Features include:
Lightweight execution units based on greenlets.
API that re-uses concepts from the Python standard library (for examples there are events and queues).
Cooperative DNS queries performed through a threadpool, dnspython, or c-ares.
Monkey patching utility to get 3rd party modules to become cooperative
TCP/UDP/HTTP servers
Subprocess support (through gevent.subprocess)
Thread pools
gevent is inspired by eventlet but features a more consistent API, simpler implementation and better performance. Read why others use gevent and check out the list of the open source projects based on gevent.
gevent was written by Denis Bilenko.
Since version 1.1, gevent is maintained by Jason Madden for NextThought with help from the contributors and is licensed under the MIT license.
See what’s new in the latest major release.
Check out the detailed changelog for this version.
Read the documentation online at http://www.gevent.org.
Post issues on the bug tracker, discuss and ask open ended questions on the mailing list, and find announcements and information on the blog and twitter (@gevent).
Installation and Requirements
Supported Platforms
This version of gevent runs on Python 2.7.9 and up, and many versions of Python 3 (for exact details, see the classifiers on the PyPI page or in setup.py). gevent requires the greenlet library and will install the cffi library by default on Windows. The cffi library will become the default on all platforms in a future release of gevent.
This version of gevent also runs on PyPy 7.3.7 (7.3.6 for PyPy2) or above. On PyPy, there are no external dependencies.
gevent is tested on Windows, macOS, and Linux, and should run on most other Unix-like operating systems (e.g., FreeBSD, Solaris, etc.)
Older Versions of Python
Users of older versions of Python 2 or Python 3 may install an older version of gevent. Note that these versions are generally not supported.
Python Version |
Gevent Version |
---|---|
2.5 |
1.0.x |
2.6 |
1.1.x |
<= 2.7.8 |
1.2.x |
3.3 |
1.2.x |
3.4.0 - 3.4.2 |
1.3.x |
3.4.3 |
1.4.x |
3.5.x |
20.9.0 |
Installation
gevent and greenlet can both be installed with pip, e.g., pip install gevent. Installation using buildout is also supported.
On Windows, macOS, and Linux, both gevent and greenlet are distributed as binary wheels.
Installing From Source
If you are unable to use the binary wheels (for platforms where no pre-built wheels are available or if wheel installation is disabled), you can build gevent from source. A normal pip install will fall back to doing this if no binary wheel is available. See Installing From Source for more, including common installation issues.
Extra Dependencies
There are a number of additional libraries that extend gevent’s functionality and will be used if they are available. All of these may be installed using setuptools extras, as named below, e.g., pip install gevent[events].
- events
In versions of gevent up to and including 20.5.0, this provided configurable event support using zope.event and was highly recommended.
In versions after that, this extra is empty and does nothing. It will be removed in gevent 21.0.
- dnspython
Enables a pure-Python resolver, backed by dnspython. On Python 2, this also includes idna. They can be installed with the dnspython extra.
- monitor
Enhancements to gevent’s self-monitoring capabilities. This includes the psutil library which is needed to monitor memory usage. (Note that this may not build on all platforms.)
- recommended
A shortcut for installing suggested extras together. This includes the non-test extras defined here, plus:
backports.socketpair on Python 2/Windows (beginning with release 20.6.0);
selectors2 on Python 2 (beginning with release 20.6.0).
- test
Everything needed to run the complete gevent test suite.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
Hashes for levoai_gevent-21.12.1.dev0-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e96589d1195d2fe0d1e0d943816d55259631d8614266484e57887255897f814a |
|
MD5 | 71b57e5fc6621f47e100cb6366b7c028 |
|
BLAKE2b-256 | c2722139c1c67453fad8bb6acb19b154d80b0842ecb1b524641a092302783870 |
Hashes for levoai_gevent-21.12.1.dev0-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 75a0a118218719b435323c3b428714a665e2df8c281bfefeb6d554d47723a668 |
|
MD5 | 47707e98072fe00de08abd5a86794348 |
|
BLAKE2b-256 | 24126030f93a3a6df82284420a32408c0e3a2c1d50e8a310f384c969d937c647 |
Hashes for levoai_gevent-21.12.1.dev0-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0d8f7127dcc2cacb358412e81dd31a149267178633bd3e8ad3218a1c08e54652 |
|
MD5 | 25038c6b206d0f129ccaa6cd715305fc |
|
BLAKE2b-256 | 0a1d7c801bafbec8103d7bd18f5e13d83021a2a69614a2088f8a753cec875f74 |
Hashes for levoai_gevent-21.12.1.dev0-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ba09b9456ab4a8d5baa0caa8dc0ea7533126e46f5bce7149a0081f35874f1cff |
|
MD5 | 20a5357eae0ca5b6543ca537a4b3a481 |
|
BLAKE2b-256 | c9d5336c484f72fb5171d3f57b0157ee545760d848270847c1cb98916fdb9d74 |
Hashes for levoai_gevent-21.12.1.dev0-cp36-cp36m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | accef74ba0edc3476503b9f33ed0b3e254109d72996d86b003f3fbb602b9943c |
|
MD5 | 1ec32617fcea01ec52893ae7d17d5eee |
|
BLAKE2b-256 | 24af425b87a99e3c189ec000331e6a0ca5939851af4f9a68aee07da3122c3b3e |