Beanstalkd Client for Rust

Beanstalkd is a fast, general-purpose work queue. beanstalkc-rust is a Beanstalkd Client to communicate with Beanstalkd Server based on the protocol defined here.

Inspired by rust-beanstalkd and beanstalkc.

Why

Several repositories can be found from here, why not just using one of those directly? The reasons are as follows: 1. Some of them were poorly documented; 1. Some of them were not actively developed or maintained; 1. This rust-beanstalkd repo with the most stars was already out-dated, since not all the beanstalkd commands were supported.

Features

  1. Easy to use;
  2. Support custom connection timeout;
  3. Support all the commands defined in the protocol.txt;
  4. Well documented.

Documentation

Full documentation can be found here.

Usage

More examples can be found here.

Producer

```rust use beanstalkc::Beanstalkc; use std::time;

fn main() { let mut conn = Beanstalkc::new() .host("127.0.0.1") .port(11300) .connectiontimeout(Some(time::Duration::fromsecs(10))) .connect() .expect("connection failed");

conn.use_tube("jobs").unwrap();

conn.put_default(b"hello, world").unwrap();
conn.put(
        b"Hello, rust world.",
        0,
        time::Duration::from_secs(100),
        time::Duration::from_secs(1800)
    )

} ```

Consumer

```rust use beanstalkc::Beanstalkc; use std::time;

fn main() { let mut conn = Beanstalkc::new() .host("127.0.0.1") .port(11300) .connectiontimeout(Some(time::Duration::fromsecs(10))) .connect() .expect("connection failed");

conn.watch("jobs").unwrap();

let mut job = conn.reserve().unwrap();
println!("{:#?}", job.stats());

job.delete().unwrap();

} ```

License

Licensed under the MIT license

Contribution

Please feel free to report any issues~