Skip to main content

Very fast pure-Python AMQP client

Project description

CoolAMQP

A Python client for RabbitMQ

Why CoolAMQP?

  • it supports all types of exchanges
  • it works on Python 2 and on Windows
  • tested against all versions of RabbitMQ 3.x and RabbitMQ 4.0
  • AMQP 0.9.1 client that's native Python
  • heavily optimized for speed
  • geared towards interfacing with RabbitMQ
  • traceable using opentracing
  • high coverage
  • tested in production conditions
  • full support for streams
  • 120 second stress tests are part of each release

Warning!! Since v1.3.1 development has been moved from GitHub to this GitLab. To install CoolAMQP please use

pip install coolamqp

Documentation (WIP) is available at our site.

CoolAMQP uses semantic versioning 2.0.

tl;dr - this is machine-generated compile-time. this generates classes run-time, and there are memoryviews everywhere.

This is borderline absurd.

The project is actively maintained and used in a commercial project. Tests can run either on Vagrant (Vagrantfile attached) or Travis CI, and run against RabbitMQ.

CoolAMQP won't touch your messages. It's your bags o'bytes, and your properties.

Enjoy!

Watch out for memoryviews! They're here to stay.

Notes

Assertions are sprinkled throughout the code. You may wish to run with optimizations enabled if you need every CPU cycle you can get.

Note that if you define the environment variable of COOLAMQP_FORCE_SELECT_LISTENER, CoolAMQP will use select-based networking instead of epoll based.

Current limitations

  • channel flow mechanism is not supported (#11)
  • confirm=True is not available if you're not RabbitMQ (#8)

Copyright holder change

Since SMOK sp. z o.o. was incorporated, it inherited all SMOK-related IP of previous operator of the service, DMS Serwis s.c., which continues to operate within it's designated company agreement. From there stems the copyright holder name change.

And because I haven't been paid a penny for this work, I've assumed copyright personally.

What is here

coolamqp

The core module

stress_tests

A series of stress tests to catch any race conditions

tests

A series of unit tests that need an AMQP server listening.

compile_definitions

A tool to generate definitions.py from the AMQP specification XML.

In order to compile the definitions:

  • Make sure that you have yapf and requests installed
  • then perform:
python -m compile_definitions

and you're all set. The only files modified is definitions.py.

docs

Sources for the documentation, available here.

Running unit tests

Unit tests are powered by nose. They require an available AMQP broker. If you host the broker other than localhost, set the env AMQP_HOST to correct value. The default username used is guest, and password is guest.

You can also run unit tests from Docker, if you wish so. To launch the unit test suite:

docker-compose up --build unittest

To launch the stress test suite

docker-compose up stress_tests

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

CoolAMQP-2.1.2-py2.py3-none-any.whl (98.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file CoolAMQP-2.1.2-py2.py3-none-any.whl.

File metadata

  • Download URL: CoolAMQP-2.1.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 98.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.9

File hashes

Hashes for CoolAMQP-2.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 73ea473e60f45283273ff6a9e52f8082a155e9c806d8a52dfc2ffb995040842c
MD5 b65e656142acc3ad6f60b602cb87eef5
BLAKE2b-256 5ce6641547e7d8e9f3e62fe8c9762eeaea4c6585a482f440c4b39399be81d5ad

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