20 releases

0.5.1 Mar 13, 2024
0.4.9 Jan 10, 2024
0.4.7 Nov 18, 2023
0.4.4 Jul 31, 2023
0.3.4 Sep 20, 2022

#503 in Asynchronous

Download history 346/week @ 2023-12-23 290/week @ 2023-12-30 223/week @ 2024-01-06 270/week @ 2024-01-13 283/week @ 2024-01-20 737/week @ 2024-01-27 711/week @ 2024-02-03 326/week @ 2024-02-10 839/week @ 2024-02-17 1046/week @ 2024-02-24 1530/week @ 2024-03-02 2860/week @ 2024-03-09 2966/week @ 2024-03-16 2215/week @ 2024-03-23 3111/week @ 2024-03-30 2173/week @ 2024-04-06

10,700 downloads per month
Used in apalis

MIT license

9KB
72 lines

apalis-cron

A simple yet extensible library for cron-like job scheduling for rust. Since apalis-cron is build on top of apalis which supports tower middleware, you should be able to easily add middleware such as tracing, retries, load shed, concurrency etc.

Example

use apalis::prelude::*;
use apalis::layers::{Extension, DefaultRetryPolicy, RetryLayer};
use apalis::cron::Schedule;
use tower::ServiceBuilder;
use std::str::FromStr;

#[derive(Default, Debug, Clone)]
struct Reminder;

impl Job for Reminder {
    const NAME: &'static str = "reminder::DailyReminder";
}
async fn send_reminder(job: Reminder, ctx: JobContext) {
    // Do reminder stuff
}

#[tokio::main]
async fn main() {
    let schedule = Schedule::from_str("@daily").unwrap();

    let service = ServiceBuilder::new()
        .layer(RetryLayer::new(DefaultRetryPolicy))
        .service(job_fn(send_reminder));

    let worker = WorkerBuilder::new("daily-cron-worker")
        .stream(CronStream::new(schedule).to_stream())
        .build(service);

    Monitor::new()
        .register(worker)
        .run()
        .await
        .unwrap();
}

Dependencies

~4–17MB
~203K SLoC