Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/psycopg/psycogreen
Integration of psycopg2 with coroutine libraries
https://github.com/psycopg/psycogreen
Last synced: 1 day ago
JSON representation
Integration of psycopg2 with coroutine libraries
- Host: GitHub
- URL: https://github.com/psycopg/psycogreen
- Owner: psycopg
- License: other
- Created: 2020-02-22T19:01:29.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-12-04T12:22:00.000Z (about 1 year ago)
- Last Synced: 2025-01-06T10:10:20.207Z (9 days ago)
- Language: Python
- Homepage:
- Size: 29.3 KB
- Stars: 101
- Watchers: 4
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.rst
- Funding: .github/FUNDING.yml
- License: COPYING
Awesome Lists containing this project
- awesome-django-performance - psycogreen - Integration of psycopg2 with coroutine libraries. (Database / Tools)
README
psycogreen -- psycopg2 integration with coroutine libraries
===========================================================The `psycogreen`_ package enables psycopg2 to work with coroutine libraries,
using asynchronous calls internally but offering a blocking interface so that
regular code can run unmodified.`Psycopg`_ offers `coroutines support`__ since release 2.2. Because the main
module is a C extension it cannot be monkey-patched to become
coroutine-friendly. Instead it exposes `a hook`__ that coroutine libraries can
use to install a function integrating with their event scheduler. Psycopg will
call the function whenever it executes a libpq call that may block.
`psycogreen` is a collection of "wait callbacks" useful to integrate Psycopg
with different coroutine libraries... _psycogreen: https://github.com/psycopg/psycogreen
.. _Psycopg: https://www.psycopg.org/docs/
.. __: https://www.psycopg.org/docs/advanced.html#support-for-coroutine-libraries
.. __: https://www.psycopg.org/docs/extensions.html#psycopg2.extensions.set_wait_callbackWhat about Psycopg 3?
---------------------The `Psycopg 3`_ module doesn't require psycogreen; psycogreen has no effect on
Psycopg 3.In Psycopg 3:
- gevent `is supported`__ automatically from 3.1.14 on. Please avoid to use
older versions.
- Eventlet is currently not supported, as the project doesn't seem very active
anymore. Support can be added if requested.
- uWsgi is currently in maintenance mode, so Psycopg 3 support doesn't seem
necessary... _Psycopg 3: https://www.psycopg.org/psycopg3/docs/
.. __: https://www.psycopg.org/psycopg3/docs/advanced/async.html#gevent-supportInstallation
------------``pip install psycogreen``
Module ``psycogreen.eventlet``
------------------------------`Eventlet`_ currently supports ```psycopg2` out-of-the-box and ``psycogreen``
is not necessary. See `the documentation`__ for patching instruction... _Eventlet: https://eventlet.net/
.. __: https://eventlet.net/doc/patching.html#monkeypatching-the-standard-libraryIf for any reason you want to avoid using Eventlet monkeypatching you can use
``psycogreen.eventlet.patch_psycopg()``.Function ``psycogreen.eventlet.patch_psycopg()``
Enable async processing in Psycopg integrated with the Eventlet events
loop. It is performed by registering ``eventlet_wait_callback()`` as
psycopg2 wait callback.Function ``psycogreen.eventlet.eventlet_wait_callback(conn)``
A wait callback integrating with Eventlet events loop.An example script showing concurrent usage of ``psycopg2`` with ``urlopen()``
with Eventlet is available in |tests/test_eventlet.py|__... |tests/test_eventlet.py| replace:: ``tests/test_eventlet.py``
.. __: https://github.com/psycopg/psycogreen/blob/master/tests/test_eventlet.pyModule ``psycogreen.gevent``
----------------------------In order to use psycopg2 asynchronously with `gevent`_ you can use
``psycogreen.gevent.patch_psycopg()``.Function ``psycogreen.gevent.patch_psycopg()``
Enable async processing in Psycopg integrated with the gevent events
loop. It is performed by registering ``gevent_wait_callback()`` as
psycopg2 wait callback.Function ``psycogreen.gevent.gevent_wait_callback(conn)``
A wait callback integrating with gevent events loop.An example script showing concurrent usage of ``psycopg2`` with ``urlopen()``
with gevent is available in |tests/test_gevent.py|__... _gevent: https://www.gevent.org/
.. |tests/test_gevent.py| replace:: ``tests/test_gevent.py``
.. __: https://github.com/psycopg/psycogreen/blob/master/tests/test_gevent.pyuWSGI green threads
-------------------Roberto De Ioris is writing uGreen__, a green thread implementation on top of
the `uWSGI async platform`__... __: https://projects.unbit.it/uwsgi/wiki/uGreen
.. __: https://projects.unbit.it/uwsgi/He has performed some tests using both `psycopg2 async support`__ and
`psycopg2 green support`__ and has reported no problem in their stress tests
with both the async styles... __: https://projects.unbit.it/uwsgi/browser/tests/psycopg2_green.py
.. __: https://projects.unbit.it/uwsgi/browser/tests/psycogreen_green.py