30 releases (6 stable)

2.0.7 Oct 22, 2023
2.0.4 May 23, 2023
1.0.1 May 31, 2022
1.0.0 Feb 22, 2022
0.5.0 Oct 30, 2019

#147 in Database interfaces

Download history 3286/week @ 2024-07-19 2773/week @ 2024-07-26 3330/week @ 2024-08-02 3313/week @ 2024-08-09 3822/week @ 2024-08-16 3578/week @ 2024-08-23 3124/week @ 2024-08-30 3387/week @ 2024-09-06 3067/week @ 2024-09-13 3886/week @ 2024-09-20 2977/week @ 2024-09-27 3944/week @ 2024-10-04 3674/week @ 2024-10-11 2807/week @ 2024-10-18 3696/week @ 2024-10-25 3093/week @ 2024-11-01

14,026 downloads per month
Used in 5 crates

BSD-3-Clause

255KB
6K SLoC

license Releases crates.io docs CircleCI

redismodule-rs

This crate provides an idiomatic Rust API for the Redis Modules API. It allows writing Redis modules in Rust, without needing to use raw pointers or unsafe code. See here for the most recent API documentation.

Running the example module

  1. Install Rust
  2. Install Redis, most likely using your favorite package manager (Homebrew on Mac, APT or YUM on Linux)
  3. Run cargo build --example hello
  4. Start a redis server with the hello module
    • Linux: redis-server --loadmodule ./target/debug/examples/libhello.so
    • Mac: redis-server --loadmodule ./target/debug/examples/libhello.dylib
  5. Open a Redis CLI, and run HELLO.MUL 31 11.

Writing your own module

See the examples directory for some sample modules.

This crate tries to provide high-level wrappers around the standard Redis Modules API, while preserving the API's basic concepts. Therefore, following the Redis Modules API documentation will be mostly relevant here as well.

Redis Modules based on this crate

The following are some modules that are built on this crate:

Several member of the community have written their own modules based on this.

Dependencies

~6–15MB
~216K SLoC