mikkoo


Namemikkoo JSON
Version 2.2.2 PyPI version JSON
download
home_pagehttps://github.com/gmr/mikkoo
SummaryMikkoo is a PgQ to RabbitMQ Relay
upload_time2024-01-29 16:11:39
maintainer
docs_urlNone
authorGavin M. Roy
requires_python>=3.9
licenseBSD 3-Clause License
keywords amqp postgres postgresql rabbitmq
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            Mikkoo
======
A `PgQ <https://wiki.postgresql.org/wiki/SkyTools#PgQ>`_ to
`RabbitMQ <https://www.rabbitmq.com>`_ relay. Mikkoo is a PgQ consumer that
that publishes to RabbitMQ. In addition, it includes a built in auditing
system that can be used to confirm that all PgQ events are received by
RabbitMQ.

Mikkoo is named for the rabbit in the "Clever Rabbit and the Elephant" fable.

|Version| |Downloads| |Status|

Installation
------------
Mikkoo is available on the `Python Package Index <https://pypi.python.org/pypi/mikkoo>`_
and can be installed via `pip`:

.. code:: bash

    pip install mikkoo

Once you've setup `Skytools <https://wiki.postgresql.org/wiki/SkyTools>`_ you may want to
install the optional included utility functions in `mikkoo.sql <mikkoo.sql>`_ to make usage
easier.

You can do this with a combination of ``curl`` and ``psql``:

.. code:: bash

    curl -L https://github.com/gmr/mikkoo/blob/main/mikkoo.sql | psql

This will install multiple stored procedures and an audit table in a mikkoo schema.
Take a look at the DDL to get a good idea of what each funciton is and how it can
be used.

PgQ Setup
---------

1. Install ``pgq`` into your database and create the queue:

    .. code:: sql

        # CREATE EXTENSION pgq;
        CREATE EXTENSION
        # SELECT pgq.create_queue('test');
        create_queue
        --------------
                    1
        (1 row)

2. Ensure that `pgqd <http://skytools.projects.pgfoundry.org/skytools-3.0/doc/pgqd.html>`_
   is running.

PgQ Event to AMQP Mapping
-------------------------
When inserting events into a PgQ queue, the ``pgq.insert_event/7`` function
should be used with the following field mappings:

+---------------+-----------------------+
| PgQ Event     | AMQP                  |
+===============+=======================+
| ``ev_type``   | Routing Key           |
+---------------+-----------------------+
| ``ev_data``   | Message body          |
+---------------+-----------------------+
| ``ev_extra1`` | Exchange              |
+---------------+-----------------------+
| ``ev_extra2`` | Content-Type Property |
+---------------+-----------------------+
| ``ev_extra3`` | AMQP Properties [1]_  |
+---------------+-----------------------+
| ``ev_extra4`` | Headers [2]_          |
+---------------+-----------------------+
| ``ev_time``   | Headers.timetamp      |
+---------------+-----------------------+
| ``ev_txid``   | Headers.txid          |
+---------------+-----------------------+

.. [1] AMQP properties should be set as a JSON blob. Values set in the ``ev_extra3``
       field will overwrite the automatically created properties ``app_id``,
       ``content_type``, ``correlation_id``, ``headers``, and ``timestamp``.
.. [2] If ``ev_extra4`` is specified and is a JSON key/value dictionary, it will
       be assigned to the ``headers`` AMQP property.

There is a convenience schema in the `mikkoo.sql <mikkoo.sql>`_ file that adds
stored procedures for creating properly formatted mikkoo events in PgQ. In
addition, there is are auditing functions that allow for the creation of an
audit-log of events that were sent to PgQ.


AMQP Message Properties
^^^^^^^^^^^^^^^^^^^^^^^
The following table defines the available fields that can be set in a JSON blob
in the ``ev_extra3`` field when inserting an event.

+----------------------+----------------+
| Property             | PgSQL Type     |
+======================+================+
| ``app_id``           | text           |
+----------------------+----------------+
| ``content_encoding`` | text           |
+----------------------+----------------+
| ``content_type``     | text           |
+----------------------+----------------+
| ``correlation_id``   | text           |
+----------------------+----------------+
| ``delivery_mode``    | int2           |
+----------------------+----------------+
| ``expiration``       | text           |
+----------------------+----------------+
| ``message_id``       | text           |
+----------------------+----------------+
| ``headers``          | text/json [3]_ |
+----------------------+----------------+
| ``timestamp``        | int4           |
+----------------------+----------------+
| ``type``             | text           |
+----------------------+----------------+
| ``priority``         | int4           |
+----------------------+----------------+
| ``user_id``          | text           |
+----------------------+----------------+

.. [3] ``headers`` should be sent to a key/value JSON blob if specified

Values assigned in the JSON blob provided to ``ev_extra3`` take precedence over
the automatically assigned ``app_id``, ``content_type``, ``correlation_id``,
``headers``, and ``timestamp`` values created by Mikkoo at processing time.

As of 1.0, Mikkoo will automatically add four AMQP headers property values. These
values will not overwrite any values with the same name specified in ``ev_extra4``.
overwriting values with the same name, even if they are specified in the
The ``sequence`` value is a dynamically generated ID that attempts to provide
fuzzy distributed ordering information. The ``timestamp`` value is the ISO-8601
representation of the ``ev_time`` field, which is created when an event is added
to PgQ. The ``txid`` value is the ``ev_txid`` value, the PgQ transaction ID for
the event.  These values are added to help provide some level of deterministic
ordering. The ``origin`` value is the hostname of the server that Mikkoo is running
on.

Event Insertion Example
-----------------------

The following example inserts a JSON blob message body of ``{"foo": "bar"}`` that
will be published to the ``postgres`` exchange in RabbitMQ using the ``test.routing-key``
routing key. The content type is specified in ``ev_extra2`` and the AMQP ``type``
message property is specified in ``ev_extra3``.

.. code:: sql

    # SELECT pgq.insert_event('test', 'test.routing-key', '{"foo": "bar"}', 'postgres', 'application/json', '{"type": "example"}', '');
     insert_event
    --------------
                4
    (1 row)

When this message is received by RabbitMQ it will have a message body of:

.. code:: json

    {"foo": "bar"}

And it will have message properties similar to the following:

+----------------------+-------------------------------------------------------+
| Property             | Example Value                                         |
+======================+=======================================================+
| ``app_id``           | ``mikkoo``                                            |
+----------------------+-------------------------------------------------------+
| ``content_type``     | ``application/json``                                  |
+----------------------+-------------------------------------------------------+
| ``correlation_id``   | ``0ad6b212-4c84-4eb0-8782-9a44bdfe949f``              |
+----------------------+-------------------------------------------------------+
| ``headers``          | +---------------+-----------------------------------+ |
|                      | | Key           | Example Value                     | |
|                      | +===============+===================================+ |
|                      | | ``origin``    | ``mikkoo.domain.com``             | |
|                      | +---------------+-----------------------------------+ |
|                      | | ``sequence``  | ``4539586784185129828``           | |
|                      | +---------------+-----------------------------------+ |
|                      | | ``timestamp`` | ``2017-02-23 06:17:14.471682-00`` | |
|                      | +---------------+-----------------------------------+ |
|                      | | ``txid``      | ``41356335556``                   | |
|                      | +---------------+-----------------------------------+ |
+----------------------+-------------------------------------------------------+
| ``timestamp``        | ``1449600290``                                        |
+----------------------+-------------------------------------------------------+
| ``type``             | ``example``                                           |
+----------------------+-------------------------------------------------------+

Configuration
-------------
The Mikkoo configuration file uses `YAML <http://yaml.org>`_ for markup and allows
for one or more PgQ queue to be processed.

If you have a Sentry or a Sentry account, the ``Application/sentry_dsn`` setting
will turn on sentry exception logging, if the
`raven <https://pypi.python.org/pypi/raven>`_ client library is installed.

Queues are configured by name under the ``Application/workers`` stanza. The
following example configures two workers for the processing of a queue named
``invoices``. Each worker process connects to a local PostgreSQL and RabbitMQ
instance using default credentials.

.. code:: yaml

    Application:
      workers:
         invoices:
           postgres_url: postgresql://localhost:5432/postgres
           rabbitmq:
             host: localhost
             port: 5671
             vhost: /
             ssl_options:
               protocol: 2
           confirm: false

Queue Configuration Options
^^^^^^^^^^^^^^^^^^^^^^^^^^^
The following table details the configuration options available per queue:

+--------------------+---------------------------------------------------------------------+
| Key                | Description                                                         |
+====================+=====================================================================+
| ``confirm``        | Enable/Disable RabbitMQ Publisher Confirmations. Default: ``True``  |
+--------------------+---------------------------------------------------------------------+
| ``consumer_name``  | Overwrite the default PgQ consumer name. Default: ``mikkoo``        |
+--------------------+---------------------------------------------------------------------+
| ``max_failures``   | Maximum failures before discarding an event. Default: ``10``        |
+--------------------+---------------------------------------------------------------------+
| ``postgresql_url`` | The url for connecting to PostgreSQL                                |
+--------------------+---------------------------------------------------------------------+
| ``rabbitmq``       | Data structure for connection parameters to connect to RabbitMQ     |
+--------------------+---------------------------------------------------------------------+
| ``retry_delay``    | How long in seconds until PgQ emits failed events. Default: ``10``  |
+--------------------+---------------------------------------------------------------------+
| ``unregister``     | Unregister a consumer with PgQ on shutdown. Default: ``True``       |
+--------------------+---------------------------------------------------------------------+
| ``wait_duration``  | How long to wait before checking the queue after the last empty     |
|                    | result. Default: ``10``                                             |
+--------------------+---------------------------------------------------------------------+

``rabbitmq`` attributes:

+----------------------+---------------------------------------------------------------+
| Attribute            | Description                                                   |
+======================+===============================================================+
| `host`               | The hostname or ip address of the RabbitMQ server (str)       |
+----------------------+---------------------------------------------------------------+
| `port`               | The port of the RabbitMQ server (int)                         |
+----------------------+---------------------------------------------------------------+
| `vhost`              | The virtual host to connect to (str)                          |
+----------------------+---------------------------------------------------------------+
| `username`           | The username to connect as (str)                              |
+----------------------+---------------------------------------------------------------+
| `password`           | The password to use (str)                                     |
+----------------------+---------------------------------------------------------------+
| `ssl_options`        | Optional: the SSL options for the `SSL connection socket`_    |
+----------------------+---------------------------------------------------------------+
| `heartbeat_interval` | Optional: the AMQP heartbeat interval (int) default: 300 sec  |
+----------------------+---------------------------------------------------------------+

``ssl_options`` attributes:

+----------------+------------------------------------------------------------------------------------------+
| Attribute      | Description                                                                              |
+================+==============+===========================================================================+
| `ca_certs`     | The file path to the concatenated list of CA certificates (str)                          |
+----------------+------------------------------------------------------------------------------------------+
| `ca_path`      | The directory path to the PEM formatted CA certificates (str)                            |
+----------------+------------------------------------------------------------------------------------------+
| `ca_data`      | The PEM encoded CA certificates (str)                                                    |
+----------------+------------------------------------------------------------------------------------------+
| `prototcol`    | The ssl `PROTOCOL_*`_ enum integer value. Default: ``2`` for enum ``PROTOCOL_TLS`` (int) |
+----------------+------------------------------------------------------------------------------------------+
| `certfile`     | The file path to the PEM formatted certificate file (str)                                |
+----------------+------------------------------------------------------------------------------------------+
| `keyfile`      | The file path to the certificate private key (str)                                       |
+----------------+------------------------------------------------------------------------------------------+
| `password`     | The password for decrypting the ``keyfile`` private key (str)                            |
+----------------+------------------------------------------------------------------------------------------+
| `ciphers`      | The set of available ciphers in the OpenSSL cipher list format (str)                     |
+----------------+------------------------------------------------------------------------------------------+

.. _SSL connection socket: https://docs.python.org/3/library/ssl.html#ssl.wrap_socket
.. _PROTOCOL_*: https://docs.python.org/3/library/ssl.html#ssl.SSLContext

Example Configuration
^^^^^^^^^^^^^^^^^^^^^

The following is an example of a full configuration file:

.. code:: yaml

    Application:

      poll_interval: 10
      sentry_dsn: [YOUR SENTRY DSN]

      statsd:
        enabled: true
        host: localhost
        port: 8125

      workers:
        test:
          confirm: False
          consumer_name: my_consumer
          max_failures: 5
          postgres_url: postgresql://localhost:5432/postgres
          rabbitmq:
            host: localhost
            port: 5671
            username: guest
            password: guest
            ssl_options:
              protocol: 2
          retry_delay: 5
          unregister: False
          wait_duration: 5

    Daemon:
      user: mikkoo
      pidfile: /var/run/mikkoo

    Logging:
      version: 1
      formatters:
        verbose:
          format: '%(levelname) -10s %(asctime)s  %(process)-6d %(processName) -20s %(name) -18s: %(message)s'
          datefmt: '%Y-%m-%d %H:%M:%S'
      handlers:
        console:
          class: logging.StreamHandler
          formatter: verbose
          debug_only: True
      loggers:
        helper:
          handlers: [console]
          level: INFO
          propagate: true
        mikkoo:
          handlers: [console]
          level: INFO
          propagate: true
        pika:
          handlers: [console]
          level: ERROR
          propagate: true
        queries:
          handlers: [console]
          level: ERROR
          propagate: true
        tornado:
          handlers: [console]
          level: ERROR
          propagate: true
      root:
        handlers: [console]
        level: CRITICAL
        propagate: true
      disable_existing_loggers: true
      incremental: false

Running Mikkoo
--------------
After creating a configuration file for Mikkoo like the one above, simply run the mikkoo application providing the path to the configuration file:

.. code:: bash

    mikkoo -c mikkoo.yml

The application will attempt to daemonize unless you use the ``-f`` foreground CLI switch.

Mikkoo's CLI help can be invoked with ``--help`` and yields the following output:

.. code:: bash

    $ mikkoo -h
    usage: mikkoo [-h] [-c CONFIG] [-f]

    Mikkoo is a PgQ to RabbitMQ Relay

    optional arguments:
      -h, --help            show this help message and exit
      -c CONFIG, --config CONFIG
                            Path to the configuration file
      -f, --foreground      Run the application interactively


.. |Version| image:: https://img.shields.io/pypi/v/mikkoo.svg?
   :target: http://badge.fury.io/py/mikkoo

.. |Status| image:: https://github.com/gmr/mikkoo/actions/workflows/testing.yaml/badge.svg?
   :target: https://travis-ci.org/gmr/mikkoo

.. |Downloads| image:: https://img.shields.io/pypi/dm/mikkoo.svg?
   :target: https://pypi.python.org/pypi/mikkoo

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/gmr/mikkoo",
    "name": "mikkoo",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": "",
    "keywords": "amqp,postgres,postgresql,rabbitmq",
    "author": "Gavin M. Roy",
    "author_email": "gavinmroy@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/12/fe/600806543be20164f440cfab2498c1cc2efe08c67bf6554891add2001b42/mikkoo-2.2.2.tar.gz",
    "platform": null,
    "description": "Mikkoo\n======\nA `PgQ <https://wiki.postgresql.org/wiki/SkyTools#PgQ>`_ to\n`RabbitMQ <https://www.rabbitmq.com>`_ relay. Mikkoo is a PgQ consumer that\nthat publishes to RabbitMQ. In addition, it includes a built in auditing\nsystem that can be used to confirm that all PgQ events are received by\nRabbitMQ.\n\nMikkoo is named for the rabbit in the \"Clever Rabbit and the Elephant\" fable.\n\n|Version| |Downloads| |Status|\n\nInstallation\n------------\nMikkoo is available on the `Python Package Index <https://pypi.python.org/pypi/mikkoo>`_\nand can be installed via `pip`:\n\n.. code:: bash\n\n    pip install mikkoo\n\nOnce you've setup `Skytools <https://wiki.postgresql.org/wiki/SkyTools>`_ you may want to\ninstall the optional included utility functions in `mikkoo.sql <mikkoo.sql>`_ to make usage\neasier.\n\nYou can do this with a combination of ``curl`` and ``psql``:\n\n.. code:: bash\n\n    curl -L https://github.com/gmr/mikkoo/blob/main/mikkoo.sql | psql\n\nThis will install multiple stored procedures and an audit table in a mikkoo schema.\nTake a look at the DDL to get a good idea of what each funciton is and how it can\nbe used.\n\nPgQ Setup\n---------\n\n1. Install ``pgq`` into your database and create the queue:\n\n    .. code:: sql\n\n        # CREATE EXTENSION pgq;\n        CREATE EXTENSION\n        # SELECT pgq.create_queue('test');\n        create_queue\n        --------------\n                    1\n        (1 row)\n\n2. Ensure that `pgqd <http://skytools.projects.pgfoundry.org/skytools-3.0/doc/pgqd.html>`_\n   is running.\n\nPgQ Event to AMQP Mapping\n-------------------------\nWhen inserting events into a PgQ queue, the ``pgq.insert_event/7`` function\nshould be used with the following field mappings:\n\n+---------------+-----------------------+\n| PgQ Event     | AMQP                  |\n+===============+=======================+\n| ``ev_type``   | Routing Key           |\n+---------------+-----------------------+\n| ``ev_data``   | Message body          |\n+---------------+-----------------------+\n| ``ev_extra1`` | Exchange              |\n+---------------+-----------------------+\n| ``ev_extra2`` | Content-Type Property |\n+---------------+-----------------------+\n| ``ev_extra3`` | AMQP Properties [1]_  |\n+---------------+-----------------------+\n| ``ev_extra4`` | Headers [2]_          |\n+---------------+-----------------------+\n| ``ev_time``   | Headers.timetamp      |\n+---------------+-----------------------+\n| ``ev_txid``   | Headers.txid          |\n+---------------+-----------------------+\n\n.. [1] AMQP properties should be set as a JSON blob. Values set in the ``ev_extra3``\n       field will overwrite the automatically created properties ``app_id``,\n       ``content_type``, ``correlation_id``, ``headers``, and ``timestamp``.\n.. [2] If ``ev_extra4`` is specified and is a JSON key/value dictionary, it will\n       be assigned to the ``headers`` AMQP property.\n\nThere is a convenience schema in the `mikkoo.sql <mikkoo.sql>`_ file that adds\nstored procedures for creating properly formatted mikkoo events in PgQ. In\naddition, there is are auditing functions that allow for the creation of an\naudit-log of events that were sent to PgQ.\n\n\nAMQP Message Properties\n^^^^^^^^^^^^^^^^^^^^^^^\nThe following table defines the available fields that can be set in a JSON blob\nin the ``ev_extra3`` field when inserting an event.\n\n+----------------------+----------------+\n| Property             | PgSQL Type     |\n+======================+================+\n| ``app_id``           | text           |\n+----------------------+----------------+\n| ``content_encoding`` | text           |\n+----------------------+----------------+\n| ``content_type``     | text           |\n+----------------------+----------------+\n| ``correlation_id``   | text           |\n+----------------------+----------------+\n| ``delivery_mode``    | int2           |\n+----------------------+----------------+\n| ``expiration``       | text           |\n+----------------------+----------------+\n| ``message_id``       | text           |\n+----------------------+----------------+\n| ``headers``          | text/json [3]_ |\n+----------------------+----------------+\n| ``timestamp``        | int4           |\n+----------------------+----------------+\n| ``type``             | text           |\n+----------------------+----------------+\n| ``priority``         | int4           |\n+----------------------+----------------+\n| ``user_id``          | text           |\n+----------------------+----------------+\n\n.. [3] ``headers`` should be sent to a key/value JSON blob if specified\n\nValues assigned in the JSON blob provided to ``ev_extra3`` take precedence over\nthe automatically assigned ``app_id``, ``content_type``, ``correlation_id``,\n``headers``, and ``timestamp`` values created by Mikkoo at processing time.\n\nAs of 1.0, Mikkoo will automatically add four AMQP headers property values. These\nvalues will not overwrite any values with the same name specified in ``ev_extra4``.\noverwriting values with the same name, even if they are specified in the\nThe ``sequence`` value is a dynamically generated ID that attempts to provide\nfuzzy distributed ordering information. The ``timestamp`` value is the ISO-8601\nrepresentation of the ``ev_time`` field, which is created when an event is added\nto PgQ. The ``txid`` value is the ``ev_txid`` value, the PgQ transaction ID for\nthe event.  These values are added to help provide some level of deterministic\nordering. The ``origin`` value is the hostname of the server that Mikkoo is running\non.\n\nEvent Insertion Example\n-----------------------\n\nThe following example inserts a JSON blob message body of ``{\"foo\": \"bar\"}`` that\nwill be published to the ``postgres`` exchange in RabbitMQ using the ``test.routing-key``\nrouting key. The content type is specified in ``ev_extra2`` and the AMQP ``type``\nmessage property is specified in ``ev_extra3``.\n\n.. code:: sql\n\n    # SELECT pgq.insert_event('test', 'test.routing-key', '{\"foo\": \"bar\"}', 'postgres', 'application/json', '{\"type\": \"example\"}', '');\n     insert_event\n    --------------\n                4\n    (1 row)\n\nWhen this message is received by RabbitMQ it will have a message body of:\n\n.. code:: json\n\n    {\"foo\": \"bar\"}\n\nAnd it will have message properties similar to the following:\n\n+----------------------+-------------------------------------------------------+\n| Property             | Example Value                                         |\n+======================+=======================================================+\n| ``app_id``           | ``mikkoo``                                            |\n+----------------------+-------------------------------------------------------+\n| ``content_type``     | ``application/json``                                  |\n+----------------------+-------------------------------------------------------+\n| ``correlation_id``   | ``0ad6b212-4c84-4eb0-8782-9a44bdfe949f``              |\n+----------------------+-------------------------------------------------------+\n| ``headers``          | +---------------+-----------------------------------+ |\n|                      | | Key           | Example Value                     | |\n|                      | +===============+===================================+ |\n|                      | | ``origin``    | ``mikkoo.domain.com``             | |\n|                      | +---------------+-----------------------------------+ |\n|                      | | ``sequence``  | ``4539586784185129828``           | |\n|                      | +---------------+-----------------------------------+ |\n|                      | | ``timestamp`` | ``2017-02-23 06:17:14.471682-00`` | |\n|                      | +---------------+-----------------------------------+ |\n|                      | | ``txid``      | ``41356335556``                   | |\n|                      | +---------------+-----------------------------------+ |\n+----------------------+-------------------------------------------------------+\n| ``timestamp``        | ``1449600290``                                        |\n+----------------------+-------------------------------------------------------+\n| ``type``             | ``example``                                           |\n+----------------------+-------------------------------------------------------+\n\nConfiguration\n-------------\nThe Mikkoo configuration file uses `YAML <http://yaml.org>`_ for markup and allows\nfor one or more PgQ queue to be processed.\n\nIf you have a Sentry or a Sentry account, the ``Application/sentry_dsn`` setting\nwill turn on sentry exception logging, if the\n`raven <https://pypi.python.org/pypi/raven>`_ client library is installed.\n\nQueues are configured by name under the ``Application/workers`` stanza. The\nfollowing example configures two workers for the processing of a queue named\n``invoices``. Each worker process connects to a local PostgreSQL and RabbitMQ\ninstance using default credentials.\n\n.. code:: yaml\n\n    Application:\n      workers:\n         invoices:\n           postgres_url: postgresql://localhost:5432/postgres\n           rabbitmq:\n             host: localhost\n             port: 5671\n             vhost: /\n             ssl_options:\n               protocol: 2\n           confirm: false\n\nQueue Configuration Options\n^^^^^^^^^^^^^^^^^^^^^^^^^^^\nThe following table details the configuration options available per queue:\n\n+--------------------+---------------------------------------------------------------------+\n| Key                | Description                                                         |\n+====================+=====================================================================+\n| ``confirm``        | Enable/Disable RabbitMQ Publisher Confirmations. Default: ``True``  |\n+--------------------+---------------------------------------------------------------------+\n| ``consumer_name``  | Overwrite the default PgQ consumer name. Default: ``mikkoo``        |\n+--------------------+---------------------------------------------------------------------+\n| ``max_failures``   | Maximum failures before discarding an event. Default: ``10``        |\n+--------------------+---------------------------------------------------------------------+\n| ``postgresql_url`` | The url for connecting to PostgreSQL                                |\n+--------------------+---------------------------------------------------------------------+\n| ``rabbitmq``       | Data structure for connection parameters to connect to RabbitMQ     |\n+--------------------+---------------------------------------------------------------------+\n| ``retry_delay``    | How long in seconds until PgQ emits failed events. Default: ``10``  |\n+--------------------+---------------------------------------------------------------------+\n| ``unregister``     | Unregister a consumer with PgQ on shutdown. Default: ``True``       |\n+--------------------+---------------------------------------------------------------------+\n| ``wait_duration``  | How long to wait before checking the queue after the last empty     |\n|                    | result. Default: ``10``                                             |\n+--------------------+---------------------------------------------------------------------+\n\n``rabbitmq`` attributes:\n\n+----------------------+---------------------------------------------------------------+\n| Attribute            | Description                                                   |\n+======================+===============================================================+\n| `host`               | The hostname or ip address of the RabbitMQ server (str)       |\n+----------------------+---------------------------------------------------------------+\n| `port`               | The port of the RabbitMQ server (int)                         |\n+----------------------+---------------------------------------------------------------+\n| `vhost`              | The virtual host to connect to (str)                          |\n+----------------------+---------------------------------------------------------------+\n| `username`           | The username to connect as (str)                              |\n+----------------------+---------------------------------------------------------------+\n| `password`           | The password to use (str)                                     |\n+----------------------+---------------------------------------------------------------+\n| `ssl_options`        | Optional: the SSL options for the `SSL connection socket`_    |\n+----------------------+---------------------------------------------------------------+\n| `heartbeat_interval` | Optional: the AMQP heartbeat interval (int) default: 300 sec  |\n+----------------------+---------------------------------------------------------------+\n\n``ssl_options`` attributes:\n\n+----------------+------------------------------------------------------------------------------------------+\n| Attribute      | Description                                                                              |\n+================+==============+===========================================================================+\n| `ca_certs`     | The file path to the concatenated list of CA certificates (str)                          |\n+----------------+------------------------------------------------------------------------------------------+\n| `ca_path`      | The directory path to the PEM formatted CA certificates (str)                            |\n+----------------+------------------------------------------------------------------------------------------+\n| `ca_data`      | The PEM encoded CA certificates (str)                                                    |\n+----------------+------------------------------------------------------------------------------------------+\n| `prototcol`    | The ssl `PROTOCOL_*`_ enum integer value. Default: ``2`` for enum ``PROTOCOL_TLS`` (int) |\n+----------------+------------------------------------------------------------------------------------------+\n| `certfile`     | The file path to the PEM formatted certificate file (str)                                |\n+----------------+------------------------------------------------------------------------------------------+\n| `keyfile`      | The file path to the certificate private key (str)                                       |\n+----------------+------------------------------------------------------------------------------------------+\n| `password`     | The password for decrypting the ``keyfile`` private key (str)                            |\n+----------------+------------------------------------------------------------------------------------------+\n| `ciphers`      | The set of available ciphers in the OpenSSL cipher list format (str)                     |\n+----------------+------------------------------------------------------------------------------------------+\n\n.. _SSL connection socket: https://docs.python.org/3/library/ssl.html#ssl.wrap_socket\n.. _PROTOCOL_*: https://docs.python.org/3/library/ssl.html#ssl.SSLContext\n\nExample Configuration\n^^^^^^^^^^^^^^^^^^^^^\n\nThe following is an example of a full configuration file:\n\n.. code:: yaml\n\n    Application:\n\n      poll_interval: 10\n      sentry_dsn: [YOUR SENTRY DSN]\n\n      statsd:\n        enabled: true\n        host: localhost\n        port: 8125\n\n      workers:\n        test:\n          confirm: False\n          consumer_name: my_consumer\n          max_failures: 5\n          postgres_url: postgresql://localhost:5432/postgres\n          rabbitmq:\n            host: localhost\n            port: 5671\n            username: guest\n            password: guest\n            ssl_options:\n              protocol: 2\n          retry_delay: 5\n          unregister: False\n          wait_duration: 5\n\n    Daemon:\n      user: mikkoo\n      pidfile: /var/run/mikkoo\n\n    Logging:\n      version: 1\n      formatters:\n        verbose:\n          format: '%(levelname) -10s %(asctime)s  %(process)-6d %(processName) -20s %(name) -18s: %(message)s'\n          datefmt: '%Y-%m-%d %H:%M:%S'\n      handlers:\n        console:\n          class: logging.StreamHandler\n          formatter: verbose\n          debug_only: True\n      loggers:\n        helper:\n          handlers: [console]\n          level: INFO\n          propagate: true\n        mikkoo:\n          handlers: [console]\n          level: INFO\n          propagate: true\n        pika:\n          handlers: [console]\n          level: ERROR\n          propagate: true\n        queries:\n          handlers: [console]\n          level: ERROR\n          propagate: true\n        tornado:\n          handlers: [console]\n          level: ERROR\n          propagate: true\n      root:\n        handlers: [console]\n        level: CRITICAL\n        propagate: true\n      disable_existing_loggers: true\n      incremental: false\n\nRunning Mikkoo\n--------------\nAfter creating a configuration file for Mikkoo like the one above, simply run the mikkoo application providing the path to the configuration file:\n\n.. code:: bash\n\n    mikkoo -c mikkoo.yml\n\nThe application will attempt to daemonize unless you use the ``-f`` foreground CLI switch.\n\nMikkoo's CLI help can be invoked with ``--help`` and yields the following output:\n\n.. code:: bash\n\n    $ mikkoo -h\n    usage: mikkoo [-h] [-c CONFIG] [-f]\n\n    Mikkoo is a PgQ to RabbitMQ Relay\n\n    optional arguments:\n      -h, --help            show this help message and exit\n      -c CONFIG, --config CONFIG\n                            Path to the configuration file\n      -f, --foreground      Run the application interactively\n\n\n.. |Version| image:: https://img.shields.io/pypi/v/mikkoo.svg?\n   :target: http://badge.fury.io/py/mikkoo\n\n.. |Status| image:: https://github.com/gmr/mikkoo/actions/workflows/testing.yaml/badge.svg?\n   :target: https://travis-ci.org/gmr/mikkoo\n\n.. |Downloads| image:: https://img.shields.io/pypi/dm/mikkoo.svg?\n   :target: https://pypi.python.org/pypi/mikkoo\n",
    "bugtrack_url": null,
    "license": "BSD 3-Clause License",
    "summary": "Mikkoo is a PgQ to RabbitMQ Relay",
    "version": "2.2.2",
    "project_urls": {
        "Bug Tracker": "https://github.com/gmr/mikkoo/issues",
        "Documentation": "https://mikkoo.readthedocs.io",
        "Homepage": "https://github.com/gmr/mikkoo",
        "Source Code": "https://github.com/gmr/mikkoo/"
    },
    "split_keywords": [
        "amqp",
        "postgres",
        "postgresql",
        "rabbitmq"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "12fe600806543be20164f440cfab2498c1cc2efe08c67bf6554891add2001b42",
                "md5": "ff79a96fd548ab7889642b2212c42166",
                "sha256": "5b43b5f5b4c9c77718ee237fea150e77bb912497d0de231837b5a01d902d52dd"
            },
            "downloads": -1,
            "filename": "mikkoo-2.2.2.tar.gz",
            "has_sig": false,
            "md5_digest": "ff79a96fd548ab7889642b2212c42166",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 25956,
            "upload_time": "2024-01-29T16:11:39",
            "upload_time_iso_8601": "2024-01-29T16:11:39.811156Z",
            "url": "https://files.pythonhosted.org/packages/12/fe/600806543be20164f440cfab2498c1cc2efe08c67bf6554891add2001b42/mikkoo-2.2.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-01-29 16:11:39",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "gmr",
    "github_project": "mikkoo",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "mikkoo"
}
        
Elapsed time: 3.60326s