Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/meltwater/gen_rmq
Elixir AMQP consumer and publisher behaviours
https://github.com/meltwater/gen_rmq
abstraction amqp behaviours clientdata-no elixir lifecycle-sunset otp production-dependency purpose-library rabbitmq testing usage-application
Last synced: 3 months ago
JSON representation
Elixir AMQP consumer and publisher behaviours
- Host: GitHub
- URL: https://github.com/meltwater/gen_rmq
- Owner: meltwater
- License: mit
- Archived: true
- Created: 2018-03-14T10:35:37.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-05-25T13:29:41.000Z (over 1 year ago)
- Last Synced: 2024-05-01T15:46:47.400Z (9 months ago)
- Topics: abstraction, amqp, behaviours, clientdata-no, elixir, lifecycle-sunset, otp, production-dependency, purpose-library, rabbitmq, testing, usage-application
- Language: Elixir
- Homepage:
- Size: 318 KB
- Stars: 181
- Watchers: 21
- Forks: 44
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - Set of behaviours meant to be used to create RabbitMQ consumers and publishers. (Queue)
- fucking-awesome-elixir - gen_rmq - Set of behaviours meant to be used to create RabbitMQ consumers and publishers. (Queue)
- awesome-elixir - gen_rmq - Set of behaviours meant to be used to create RabbitMQ consumers and publishers. (Queue)
README
[![Build Status](https://github.com/meltwater/gen_rmq/workflows/GenRMQ%20CI/badge.svg)](https://github.com/meltwater/gen_rmq/actions?query=workflow%3A%22GenRMQ+CI%22)
[![Hex Version](http://img.shields.io/hexpm/v/gen_rmq.svg)](https://hex.pm/packages/gen_rmq)
[![Coverage Status](https://coveralls.io/repos/github/meltwater/gen_rmq/badge.svg?branch=master)](https://coveralls.io/github/meltwater/gen_rmq?branch=master)
[![Hex.pm Download Total](https://img.shields.io/hexpm/dt/gen_rmq.svg?style=flat-square)](https://hex.pm/packages/gen_rmq)
[![Dependabot Status](https://api.dependabot.com/badges/status?host=github&repo=meltwater/gen_rmq)](https://dependabot.com)# GenRMQ
GenRMQ is a set of [behaviours][behaviours] meant to be used to create
RabbitMQ consumers and publishers, as fully OTP compliant GenServers.Internally it is using the [AMQP][amqp] elixir RabbitMQ client. The idea
is to reduce boilerplate consumer / publisher code, which usually
includes:- creating connection / channel and keeping it in a state
- creating and binding queue
- handling reconnections / consumer cancellationsGenRMQ provides the following functionality:
- `GenRMQ.Consumer` - a behaviour for implementing RabbitMQ consumers ([example][example_consumer])
- `GenRMQ.Publisher` - a behaviour for implementing RabbitMQ publishers ([example][example_publisher])
- `GenRMQ.Processor` - a behaviour for implementing RabbitMQ message processors (this is useful to separate out business logic from your consumer) ([example][example_processor])
- `GenRMQ.Consumer.Telemetry` - telemetry events emitted by a GenRMQ consumer
- `GenRMQ.Publisher.Telemetry` - telemetry events emitted by a GenRMQ publisher
- `GenRMQ.RabbitCase` - test utilities for RabbitMQ ([example][example_rabbit_case])## Installation
GenRMG requires Elixir 1.11 or newer, running on at least OTP 22.
```elixir
def deps do
[{:gen_rmq, "~> 4.0"}]
end
```## Migrations
Version `4.0.0` has been released. Please check [how to migrate to gen_rmq `4.0.0`][migrating_to_400].
## Examples
More thorough examples for using `GenRMQ.Consumer`, `GenRMQ.Publisher`, and `GenRMQ.Processor`
can be found under [documentation][examples].### Consumer
```elixir
defmodule Consumer do
@behaviour GenRMQ.Consumer@impl GenRMQ.Consumer
def init() do
[
queue: "gen_rmq_in_queue",
exchange: "gen_rmq_exchange",
routing_key: "#",
prefetch_count: "10",
connection: "amqp://guest:guest@localhost:5672",
retry_delay_function: fn attempt -> :timer.sleep(2000 * attempt) end
]
end@impl GenRMQ.Consumer
def consumer_tag() do
"test_tag"
end@impl GenRMQ.Consumer
def handle_message(message) do
...
end@impl GenRMQ.Consumer
def handle_error(message, _reason) do
GenRMQ.Consumer.reject(message, true)
end
end
``````elixir
GenRMQ.Consumer.start_link(Consumer, name: Consumer)
```This will result in:
- durable `gen_rmq_exchange.deadletter` exchange created or redeclared
- durable `gen_rmq_in_queue_error` queue created or redeclared. It will be bound to `gen_rmq_exchange.deadletter`
- durable topic `gen_rmq_exchange` exchange created or redeclared
- durable `gen_rmq_in_queue` queue created or redeclared. It will be bound to `gen_rmq_exchange` exchange and has a deadletter exchange set to `gen_rmq_exchange.deadletter`
- every `handle_message` callback will be executed in a separate supervised Task. This can be disabled by setting `concurrency: false` in `init` callback
- on failed rabbitmq connection it will wait for a bit and then reconnectThere are many options to control the consumer setup details, please check the `c:GenRMQ.Consumer.init/0` [docs][consumer_doc] for all available settings.
### Publisher
```elixir
defmodule Publisher do
@behaviour GenRMQ.Publisherdef init() do
[
exchange: "gen_rmq_exchange",
connection: "amqp://guest:guest@localhost:5672"
]
end
end
``````elixir
GenRMQ.Publisher.start_link(Publisher, name: Publisher)
GenRMQ.Publisher.publish(Publisher, Jason.encode!(%{msg: "msg"}))
```## Documentation
### Examples
- [Consumer][example_consumer]
- [Publisher][example_publisher]
- [Processor][example_processor]### Guides
- [Basic consumer setup][guide_consumer_basic_setup]
- [Consumer with custom deadletter configuration][guide_consumer_with_custom_deadletter_configuration]
- [Consumer with custom exchange type][guide_consumer_with_custom_exchange_type]
- [Consumer with custom queue configuration][guide_consumer_with_custom_queue_configuration]
- [Consumer without deadletter configuration][without_deadletter_configuration]
- [Consumer with quorum queues][with_quorum_queue_type]### Metrics
- [Consumer Telemetry events][consumer_telemetry_events]
- [Publisher Telemetry events][publisher_telemetry_events]### Migrations
- [Version 1.0.0][migrating_to_100]
- [Version 3.0.0][migrating_to_300]
- [Version 4.0.0][migrating_to_400]## Running Tests
You need [docker-compose][docker_compose] installed.
```bash
$ make test
```## How to Contribute
Please see our [Contribution Guidelines](CONTRIBUTING.md).
Are you using GenRMQ in Production? Please let us know, we are curious to learn about your experiences!
## Maintainers
- Mateusz ([@mkorszun](https://github.com/mkorszun))
The maintainers are responsible for the general project oversight, and empowering further trusted committers (see below).
The maintainers are the ones that create new releases of GenRMQ.
## Trusted Committers
- Joel ([@vorce](https://github.com/vorce))
- [@Shemeikka](https://github.com/Shemeikka)
- Alexander ([@akoutmos](https://github.com/akoutmos))
- (alumnus) Sebastian ([@spier](https://github.com/spier))Trusted Committers are members of our community who we have explicitly added to our GitHub repository. Trusted Committers have elevated rights, allowing them to send in changes directly to branches and to approve Pull Requests. For details see [TRUSTED-COMMITTERS.md][trusted_commiters].
_Note:_ Maintainers and Trusted Committers are listed in [.github/CODEOWNERS][code_owners] in order to automatically assign PR reviews to them.
## License
The [MIT License][license].
Copyright (c) Meltwater Inc. [underthehood.meltwater.com][underthehood]
[behaviours]: https://elixir-lang.org/getting-started/typespecs-and-behaviours.html#behaviours
[amqp]: https://github.com/pma/amqp
[migrating_to_100]: https://github.com/meltwater/gen_rmq/blob/master/documentation/migrations/1.0.0.md
[migrating_to_300]: https://github.com/meltwater/gen_rmq/blob/master/documentation/migrations/3.0.0.md
[migrating_to_400]: https://github.com/meltwater/gen_rmq/blob/master/documentation/migrations/4.0.0.md
[consumer_doc]: https://github.com/meltwater/gen_rmq/blob/master/lib/consumer.ex
[docker_compose]: https://docs.docker.com/compose/
[github_prs]: https://help.github.com/articles/about-pull-requests/
[gen_rmq_issues]: https://github.com/meltwater/gen_rmq/issues
[priority_queues]: https://www.rabbitmq.com/priority.html
[underthehood]: http://underthehood.meltwater.com/
[examples]: https://github.com/meltwater/gen_rmq/blob/master/documentation/examples
[example_consumer]: https://github.com/meltwater/gen_rmq/blob/master/documentation/examples/consumer.ex
[example_publisher]: https://github.com/meltwater/gen_rmq/blob/master/documentation/examples/publisher.ex
[example_processor]: https://github.com/meltwater/gen_rmq/blob/master/documentation/examples/processor.ex
[example_rabbit_case]: https://github.com/meltwater/gen_rmq/blob/master/test/gen_rmq_publisher_test.exs
[guide_consumer_basic_setup]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/basic_setup.md
[guide_consumer_with_custom_deadletter_configuration]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/with_custom_deadletter_configuration.md
[guide_consumer_with_custom_exchange_type]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/with_custom_exchange_type.md
[guide_consumer_with_custom_queue_configuration]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/with_custom_queue_configuration.md
[without_deadletter_configuration]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/without_deadletter_configuration.md
[with_quorum_queue_type]: https://github.com/meltwater/gen_rmq/blob/master/documentation/guides/consumer/with_quorum_queue_type.md
[consumer_telemetry_events]: https://github.com/meltwater/gen_rmq/blob/master/lib/gen_rmq/consumer/telemetry.ex
[publisher_telemetry_events]: https://github.com/meltwater/gen_rmq/blob/master/lib/gen_rmq/publisher/telemetry.ex
[trusted_commiters]: https://github.com/meltwater/gen_rmq/blob/master/TRUSTED-COMMITTERS.md
[code_owners]: https://github.com/meltwater/gen_rmq/blob/master/.github/CODEOWNERS
[license]: https://github.com/meltwater/gen_rmq/blob/master/LICENSE