oppgave

Crates.iooppgave
lib.rsoppgave
version0.1.0
sourcesrc
created_at2016-02-14 18:48:45.030405
updated_at2016-02-14 18:48:45.030405
descriptionA simple Redis-based task queue
homepagehttps://github.com/badboy/oppgave
repositoryhttps://github.com/badboy/oppgave
max_upload_size
id4178
size14,158
Engine Devs (github:amethyst:engine-devs)

documentation

https://badboy.github.io/oppgave

README

oppgave - A simple Redis-based task queue

Build Status crates.io

Inspired by Ost and Kute.

A small reliable queue on top of Redis. Allows to push tasks and fetch them again. Can handle whatever task object you hand it, as long as it can be encoded and decoded to and from JSON.

The name: oppgave - task

oppgave is Norwegian for task. So oppgave is a oppgave kø, a task queue.

Sadly, characters like ø don't play to well with stable Rust. Non-ASCII identifiers are feature-gated.

If you are okay with using nightly, you can get oppgave-kø instead and add #![feature(non_ascii_idents)] to your main crate file.

Documentation

Documentation is available online.

Installation

Add it to your dependencies in Cargo.toml

[dependencies]
oppgave = "0.1.0"

Example: Producer

See examples/worker.rs for a working example. Run it with cargo run --example worker.

#[derive(RustcDecodable, RustcEncodable)]
struct Job { id: u64 }

let client = redis::Client::open("redis://127.0.0.1/").unwrap();
let con = client.get_connection().unwrap();
let producer = Queue::new("default".into(), con);

producer.push(Job{ id: 42 });

Example: Worker

See examples/worker.rs for a working example. Run it with cargo run --example worker.

#[derive(RustcDecodable, RustcEncodable)]
struct Job { id: u64 }

let client = redis::Client::open("redis://127.0.0.1/").unwrap();
let con = client.get_connection().unwrap();
let worker = Queue::new("default".into(), con);

while let Some(task) = worker.next() {
    println!("Working with Job {}", job.id);
}

License

MIT. See LICENSE.

Commit count: 47

cargo fmt