#events #message

bin+lib rust_transit_rabbit

RabbitMQ support for rust_transit

1 unstable release

0.1.0 Apr 11, 2020

#44 in #event

MIT license

33KB
681 lines

Rust Events

This is for the moment a little experiment to add a layer of abstraction on top of messaging API. This project is inspired by Mass Transit: take some decisions about the topology of the underlying messaging architecture, make it easy to create messages types ("Events").

Main Features

Multitenancy

Each event can be optionally attached a tenant, which is only an arbitrary string. A consumer can listen to events for all or one specific tenant.

Supported Backends

RabbitMQ

RabbitMQ support via lapin.

Currently you cannot choose the topology, but hopefully at some stage we can add ways to customize it.

Kafka

Kafka support via rust-rdkafka

Misc.

License

Licensed under MIT license.

Running tests

Disable parallel tests since they are integration tests RUST_LOG=info cargo test -- --nocapture --test-threads=1


lib.rs:

Implementation of Event Manager for RabbitMQ

Dependencies

~8–18MB
~246K SLoC