Skip to main content

Light PgQ Framework - queuing system for PostgreSQL

Project description

This module provides a convenient Python API to integrate PostgreSQL PgQ features with any Python application.

Presentation of PgQ

(from SkyTools README)

PgQ is a queuing system written in PL/pgSQL, Python and C code. It is based on snapshot-based event handling ideas from Slony-I, and is written for general usage.

PgQ provides an efficient, transactional queueing system with multi-node support (including work sharing and splitting, failover and switchover, for queues and for consumers).

Rules:

  • There can be several queues in a database.

  • There can be several producers than can insert into any queue.

  • There can be several consumers on one queue.

  • There can be several subconsumers on a consumer.

PgQ is split into 3 layers: Producers, Ticker and Consumers.

Producers and Consumers respectively push and read events into a queue. Producers just need to call PostgreSQL stored procedures (like a trigger on a table or a PostgreSQL call from the application). Consumers are frequently written in Python, but any language able to run PostgreSQL stored procedures can be used.

Ticker is a daemon which splits the queues into batches of events and handle the maintenance of the system.

The PgQueue module

This module provides Python functions and classes to write Producers and Consumers. It contains also a Python implementation of the Ticker engine, which mimics the original C Ticker from SkyTools: it splits batches of events, and execute maintenance tasks.

Installation

Prerequisites:

  • Python >= 2.6 or Python 3

  • psycopg2 is automatically installed as a dependency

  • (on the server) the PgQ extension version >= 3.1

On Debian / Ubuntu you will add the PostgreSQL APT repository, then install the package postgresql-x.x-pgq3 depending on the PostgreSQL version.

Finally create the extension in the database:

CREATE EXTENSION IF NOT EXISTS pgq;

You can install the pgqueue module into your environment.

pip install --update pgqueue

Example usage

You need to run the Ticker permanently. If the Ticker is off, the events will be stored into the queues, but no batch will be prepared for the consumers, and event tables will grow quickly.

For the Ticker, you have the choice between the optimized pgqd multi-database ticker written in C, and part of SkyTools, or use the simpler Python implementation provided with this module:

python -m pgqueue 'host=127.0.0.1 port=5432 user=jules password=xxxx dbname=test_db'

Let’s create a new queue, and register a consumer:

conn = psycopg2.connect("dbname=test user=postgres")
conn.autocommit = True
cur = conn.cursor()

first_q = Queue('first_queue')
first_q.create(cursor, ticker_max_lag='4 seconds')

consum_q = Consumer('first_queue', 'consumer_one')
consum_q.register(cursor)

We’re ready to produce events into the queue, and consume events later in the application:

first_q.insert_event(cursor, 'announce', 'Hello ...')
first_q.insert_event(cursor, 'announce', 'Hello world!')

# ... wait a little bit

conn.autocommit = False
for event in consum_q.next_events(cursor, commit=True):
    print(event)

You can browse the source code for advanced usage, until we write more documentation (contributions are welcomed).

Also refer to the upstream documentation for more details.

Credits

PgQ is a PostgreSQL extension which is developed by Marko Kreen. It is part of SkyTools, a package of tools in use in Skype for replication and failover.

SkyTools embeds also a pgq Python framework which provides a slightly different API.

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

pgqueue-0.3.tar.gz (13.3 kB view details)

Uploaded Source

Built Distribution

pgqueue-0.3-py2.py3-none-any.whl (11.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pgqueue-0.3.tar.gz.

File metadata

  • Download URL: pgqueue-0.3.tar.gz
  • Upload date:
  • Size: 13.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pgqueue-0.3.tar.gz
Algorithm Hash digest
SHA256 e363c031b1948a9a63fa9afd4129ab4ca8e49931c2bc2d5e51b1901a4eea917f
MD5 50827a9215276848cfd150c63a17ecd5
BLAKE2b-256 eb443cf2ff83d4fe525d004dbbc6ed484261e0f2a2bb6f8665c13df12ef5a319

See more details on using hashes here.

Provenance

File details

Details for the file pgqueue-0.3-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pgqueue-0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 141e5d93e2f8abc10d3b0abd01106276119e08b6ee64cbda045c6547071116a9
MD5 c09c7b552b26ef529ebebab492dca7ec
BLAKE2b-256 8cb209b1aa9eb8af2ba7da6a39d184d9e5303208687c2986bf618caae84a1551

See more details on using hashes here.

Provenance

Supported by

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