Skip to main content

Low-level AMQP client for Python (fork of amqplib)

Project description

Build status coverage Bitdeli badge

Version:

2.0.0rc2

Web:

http://amqp.readthedocs.org/

Download:

http://pypi.python.org/pypi/amqp/

Source:

http://github.com/celery/py-amqp/

Keywords:

amqp, rabbitmq

About

This is a fork of amqplib which was originally written by Barry Pederson. It is maintained by the Celery project, and used by kombu as a pure python alternative when librabbitmq is not available.

This library should be API compatible with librabbitmq.

Differences from amqplib

  • Supports draining events from multiple channels (Connection.drain_events)

  • Support for timeouts

  • Channels are restored after channel error, instead of having to close the connection.

  • Support for heartbeats

    • Connection.heartbeat_tick(rate=2) must called at regular intervals (half of the heartbeat value if rate is 2).

    • Or some other scheme by using Connection.send_heartbeat.

  • Supports RabbitMQ extensions:
    • Consumer Cancel Notifications
      • by default a cancel results in ChannelError being raised

      • but not if a on_cancel callback is passed to basic_consume.

    • Publisher confirms
      • Channel.confirm_select() enables publisher confirms.

      • Channel.events['basic_ack'].append(my_callback) adds a callback to be called when a message is confirmed. This callback is then called with the signature (delivery_tag, multiple).

    • Exchange-to-exchange bindings: exchange_bind / exchange_unbind.
      • Channel.confirm_select() enables publisher confirms.

      • Channel.events['basic_ack'].append(my_callback) adds a callback to be called when a message is confirmed. This callback is then called with the signature (delivery_tag, multiple).

  • Support for basic_return

  • Uses AMQP 0-9-1 instead of 0-8.
    • Channel.access_request and ticket arguments to methods removed.

    • Supports the arguments argument to basic_consume.

    • internal argument to exchange_declare removed.

    • auto_delete argument to exchange_declare deprecated

    • insist argument to Connection removed.

    • Channel.alerts has been removed.

    • Support for Channel.basic_recover_async.

    • Channel.basic_recover deprecated.

  • Exceptions renamed to have idiomatic names:
    • AMQPException -> AMQPError

    • AMQPConnectionException -> ConnectionError``

    • AMQPChannelException -> ChannelError``

    • Connection.known_hosts removed.

    • Connection no longer supports redirects.

    • exchange argument to queue_bind can now be empty to use the “default exchange”.

  • Adds Connection.is_alive that tries to detect whether the connection can still be used.

  • Adds Connection.connection_errors and .channel_errors, a list of recoverable errors.

  • Exposes the underlying socket as Connection.sock.

  • Adds Channel.no_ack_consumers to keep track of consumer tags that set the no_ack flag.

  • Slightly better at error recovery

Further

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 Distribution

amqp-2.0.0.tar.gz (102.3 kB view details)

Uploaded Source

Built Distribution

amqp-2.0.0-py2.py3-none-any.whl (59.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file amqp-2.0.0.tar.gz.

File metadata

  • Download URL: amqp-2.0.0.tar.gz
  • Upload date:
  • Size: 102.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for amqp-2.0.0.tar.gz
Algorithm Hash digest
SHA256 bb6439b2a3f7d5166aac49529e3f8ea95f6aa80483eed167a16dba4b7bb04e19
MD5 4501f0d5dd37d17aa5f5a93244d6269e
BLAKE2b-256 1762d1e46bfb7c6c8685277bfe2a974b72898ec6a926097ee421971843513a06

See more details on using hashes here.

Provenance

File details

Details for the file amqp-2.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for amqp-2.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 dc19a8c17d58dd6a79d4890e7c75f195111b39cce46819690c67e2267d7f1508
MD5 0af7b96ab0271a45576c21a60fac98b5
BLAKE2b-256 2a19acc66c77a282b570499f47d48f652ac0f88d8d6b427db67263772dd92536

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