Skip to main content

Set up your rabbit instance using a declarative yaml file.

Project description

RoboRabbit

RoboRabbit is a simple to use, opinionated, asynchronous abstraction over amqp/RabbitMQ (using aio_pika) and configuration CLI.

Features

  • Create/assert Queues, Exchanges, and Bindings on connection
  • Declarative Queue, Exchange, Binding, and Connection configuration using YAML
  • Very straight forward async message handling
  • Command line interface for bootstrapping rabbit from your roborabbit yaml config file.

Installation

pip

$ pip install roborabbit

poetry

$ poetry add roborabbit

Handle queue messages

The simplest worker possible. Connection information is in the roborabbit.yaml file. The method run() takes an dictionary with a key/value pair:

  • key: queue - string, the name of the queue to listen to
  • value: handler - function, the callback function messages will be sent to

Notes

  • Dead letter exchanges/queues are created and bound for you. (default is {queue_name}_dlq and {queue_name}_dlx)
  • Messages are rejected and pushed into the dead letter queue when an exception is thrown.
  • Messages are nacked and returned to queue when disconnected (asyncio.CancelledError).
  • Messages are acked automatically after the callback has run without exception.
  • Multiple queues can be listened to at the same time.
  • Connection is honored in the following order
    • The Connection() class
    • Connection parameters defined in your roborabbit.yaml file
    • Environment variables (see environment variables section)
    • Default RabbitMQ connection values

environment variables

  • RABBIT_HOST default 'localhost'
  • RABBIT_USER default 'guest'
  • RABBIT_PASS default 'guest'
  • RABBIT_PORT default 5432
  • RABBIT_VIRTUALHOST default '/'
  • RABBIT_PREFETCH default 10

Basic Example

from roborabbit.roborabbit import RoboRabbit
from pathlib import Path

config_path = Path('roborabbit.yaml')
robo = RoboRabbit(config_path)

async def queue_handler(msg):
    print(msg)  # your logic here

await robo.run({'queue_1', queue_handler})

Explicit connection example

If you want control over the configuration, you can pass in the roborabbit connection object.

from roborabbit.connection import Connection
from roborabbit.roborabbit import RoboRabbit
from pathlib import Path

config_path = Path('roborabbit.yaml')
connection = Connection(
    host='not.localhost.com',
    username='bob',
    password='pas123',
    port=4499,
    virtualhost='/')

robo = RoboRabbit(config_path, connection)

async def queue_handler(msg):
    print(msg)  # your logic here

async def work():
    await robo.run({'queue_1', queue_handler})

Command

roborabbit --config path/to/roborabbit.yaml

info

Usage: roborabbit [OPTIONS]

  import yaml config file and creates a dictionary from it

Options:
  --config TEXT       Path to rabbit config yaml file
  --host TEXT         RabbitMQ host
  --port TEXT         RabbitMQ port
  --virtualhost TEXT  RabbitMQ virtualhost
  --username TEXT     RabbitMQ username
  --password TEXT     RabbitMQ password
  --help              Show this message and exit.

Override environment variables

RABBIT_USER=guest
RABBIT_PASS=guest
RABBIT_HOST=localhost
RABBIT_PORT=5672
RABBIT_VHOST=/

Example yaml files

Simple declare queue, exchange, and bind

host: localhost
username: guest
password: guest
virtualhost: /
port: 5672
exchanges:
  - name: exchange_1
    type: topic
queues:
  - name: queue_1
bindings:
  - from:
      type: exchange
      name: exchange_1
    to:
      type: queue
      name: queue_1
    routing_keys:
      - records.created

Header exchange declaration and binding

host: localhost
username: guest
password: guest
virtualhost: /
port: 5672
exchanges:
  - name: exchange_2
    type: headers
queues:
  - name: queue_2
bindings:
  - from:
      type: exchange
      name: exchange_2
    to:
      type: queue
      name: queue_1
    bind_options:
      - x-match: all
        hw-action: header-value

All Values Available

# Connection info
host: localhost
username: guest
password: guest
virtualhost: /
port: 5672

# Exchange declarations
exchanges:
  - name: string
    type: topic|headers|direct|fanout # topic is default
    durable: false # default
    auto_delete: true # default

# queue declarations
queues:
  - name: string
    type: quorum # Not required. This is the default and currently only option available (For us, all our queues are quorum. We manually create the queue that needs other requirements). MR welcome
    dlq: string # default {queue_name}_dlq
    dlx: string # default {queue_name}_dlx
    durable: true # default
    robust: true # default
    auto_delete: false # default
    exclusive: false # default
    auto_delete_delay: 0 # default
    arguments: # rabbit specific key/value pairs
      key_1: value_1
      key_2: value_2

# bindings
bindings:
  - from:
      type: exchange
      name: string
    to:
      type: exchange|queue
      name: string
    routing_keys:
      - record.created  # list of string, required, unless bind_options is defined
    bind_options: # list of `x-match` and `header-key`, required if binding to a header exchange
      - x-match: all|any # header type of matcher
        header-key: string # header topic to be matched

Planned features:

  • Simple message publishing
  • Expose the underlying channel so you can drop right into aio_pika if you want.

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

roborabbit-0.4.2.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

roborabbit-0.4.2-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file roborabbit-0.4.2.tar.gz.

File metadata

  • Download URL: roborabbit-0.4.2.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.2 Darwin/21.3.0

File hashes

Hashes for roborabbit-0.4.2.tar.gz
Algorithm Hash digest
SHA256 fd1d5474b0c6e0554a587cb38fae16ad43ffde9572829d4ab1da1f34159a890b
MD5 f9ee284203ff843e5fbf09a8c9b2017e
BLAKE2b-256 acd4f2f3c6d31a1b8365fc1d6cdaee651208db923f59f9af9832d307a9b11a64

See more details on using hashes here.

File details

Details for the file roborabbit-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: roborabbit-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 11.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.2 Darwin/21.3.0

File hashes

Hashes for roborabbit-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 77d54bfc6874cb76f93c1d46ca08a9b7dcdd4670d3041556c2deb5c63f73b9ee
MD5 e5703fa08b5057c75a6810aab21c2d71
BLAKE2b-256 e0280ad922e446db2605933c7a921a934d76af93bb350971afcaabf07e1b54d9

See more details on using hashes here.

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