valkey-module

Crates.iovalkey-module
lib.rsvalkey-module
version0.1.2
sourcesrc
created_at2024-04-28 14:45:13.727028
updated_at2024-09-12 21:52:46.804039
descriptionA toolkit for building valkey modules in Rust
homepage
repositoryhttps://github.com/valkey-io/valkeymodule-rs
max_upload_size
id1223293
size481,773
Dmitry Polyakovsky (dmitrypol)

documentation

README

license Releases crates.io docs CircleCI

valkeymodule-rs

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

This repo was forked from redismodule-rs. We appreciate the contributions of the original authors.

Running the example module

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

Writing your own module

See the examples directory for some sample modules.

To optionally enter the System.alloc code paths in alloc.rs specify this in Cargo.toml of your module:

[features]
enable-system-alloc = ["valkey-module/system-alloc"]

For unit tests with System.alloc use this:

cargo test --features enable-system-alloc

For integration tests with ValkeyAlloc use this:

cargo test

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

Commit count: 560

cargo fmt