apalis-amqp provides utilities for integrating apalis with AMQP message queuing systems. It includes an AmqpBackend implementation for use with the pushing and popping messages.
- Integration between apalis and AMQP message queuing systems.
- Easy creation of AMQP-backed message queues.
- Simple consumption of AMQP messages as apalis messages.
- Supports message acknowledgement and rejection.
- Supports all apalis middleware such as rate-limiting, timeouts, filtering, sentry, prometheus etc.
- Supports persisting results to databases like
redis,postgresandsqliteamong others. - Partial support for sequential workflows.
Before attempting to connect, you need a working amqp backend. We can easily setup using Docker:
docker run -p 15672:15672 -p 5672:5672 -e RABBITMQ_DEFAULT_USER=my_user -e RABBITMQ_DEFAULT_PASS=******** rabbitmq:3.8.4-management
# Setup a Vhost
docker exec $(docker ps -q -f ancestor=rabbitmq:3.8.4-management) rabbitmqctl add_vhost my_vhost
# Add the Vhost
docker exec $(docker ps -q -f ancestor=rabbitmq:3.8.4-management) rabbitmqctl set_permissions -p my_vhost my_user ".*" ".*" ".*"docker exec $(docker ps -q -f ancestor=rabbitmq:3.8.4-management) rabbitmq-plugins directories -s
wget https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/download/3.8.17/rabbitmq_delayed_message_exchange-3.8.17.8f537ac.ez
docker cp rabbitmq_delayed_message_exchange-4.1.0.ez \
$(docker ps -q -f ancestor=rabbitmq:3.8.4-management):/opt/rabbitmq/plugins/Add apalis-amqp to your Cargo.toml
[dependencies]
apalis = "1.0.0-rc.1"
apalis-amqp = "1.0.0-rc.1"Then add to your main.rs
use apalis::prelude::*;
use apalis_amqp::AmqpBackend;
use serde::{Deserialize, Serialize};
#[derive(Debug, Serialize, Deserialize)]
struct TestMessage(usize);
async fn test_message(message: TestMessage) {
dbg!(message);
}
#[tokio::main]
async fn main() {
let env = std::env::var("AMQP_ADDR").unwrap();
let mut mq = AmqpBackend::new_from_addr(&env).await.unwrap();
mq.push(TestMessage(42)).await.unwrap();
WorkerBuilder::new("rango-amigo")
.backend(mq)
.build(test_message)
.run()
.await
.unwrap();
}use apalis::prelude::*;
use apalis_amqp::AmqpBackend;
use apalis_workflow::{Workflow, WorkflowSink};
#[tokio::main]
async fn main() {
let env = std::env::var("AMQP_ADDR").unwrap();
let mut backend = AmqpBackend::new_from_addr(&env).await.unwrap();
let workflow = Workflow::new("odd-numbers-workflow")
.and_then(|a: usize| async move { Ok::<_, BoxDynError>((0..a).collect::<Vec<_>>()) })
.and_then(|a: Vec<usize>| async move {
println!("Sum: {}", a.iter().sum::<usize>());
Ok::<_, BoxDynError>(())
});
backend.push_start(10).await.unwrap();
let worker = WorkerBuilder::new("rango-tango")
.backend(backend)
.on_event(|_ctx, ev| {
println!("On Event = {:?}", ev);
})
.build(workflow);
worker.run().await.unwrap();
}You can track your tasks using apalis-board.

apalis-amqp is licensed under the Apache license. See the LICENSE file for details.