Oxanus
Oxanus is job processing library written in Rust doesn't suck (or at least sucks in a completely different way than other options).
Oxanus goes for simplity and depth over breadth. It only aims support single backend with simple flow.
Key Features
- Isolated Queues: Separate job processing queues with independent configurations
- Retrying: Automatic retry of failed jobs with configurable backoff
- Scheduled Jobs: Schedule jobs to run at specific times or after delays
- Dynamic Queues: Create and manage queues at runtime
- Throttling: Control job processing rates with queue-based throttling
- Unique Jobs: Ensure only one instance of a job runs at a time
- Resilient Jobs: Jobs that can survive worker crashes and restarts
- Graceful Shutdown: Clean shutdown of workers with in-progress job handling
- Periodic Jobs: Run jobs on a schedule using cron-like expressions
- Resumable Jobs: Jobs that can be resumed from where they left off when they are retried
Quick Start
use ;
use ;
// Define your worker
// Define your queue
;
// Define your context
// Run your worker
async
For more detailed usage examples, check out the examples directory.
Core Concepts
Workers
Workers are the units of work in Oxanus. They implement the [Worker] trait and define the processing logic.
Queues
Queues are the channels through which jobs flow. They can be:
- Static: Defined at compile time
- Dynamic: Created at runtime with each instance being a separate queue
Each queue can have its own:
- Concurrency limits
- Throttling rules
- Retry policies
Storage
The [Storage] trait provides the interface for job persistence. It handles:
- Job enqueueing
- Job scheduling
- Job state management
- Queue monitoring
Context
The context provides shared state and utilities to workers. It can include:
- Database connections
- Configuration
- Shared resources
Configuration
Configuration is done through the [Config] builder, which allows you to:
- Register queues and workers
- Set up graceful shutdown
Error Handling
Oxanus uses a custom error type [OxanusError] that covers all possible error cases in the library.
Workers can define their own error type that implements std::error::Error.