rdkafka-sys

Low level bindings to librdkafka.

Bindings

To regenerate the bindings:

bash git submodule update --init cargo install bindgen ./update-bindings.sh

Version

The rdkafka-sys version number is in the format X.Y.Z-P, where X.Y.Z corresponds to the librdkafka version, and P indicates the version of the rust bindings.

Build

Known issues

Features

By default a submodule with the librdkafka sources pinned to a specific commit will be used to compile and statically link the library.

The dynamic-linking feature can be used to link rdkafka to a locally installed version of librdkafka: if the feature is enabled, the build script will use pkg-config to check the version of the library installed in the system, and it will configure the compiler to dynamically link against it.

The cmake-build feature builds librdkafka with its [CMake] build system, rather than its default [mklove]-based build system. This feature requires that CMake is installed on the build machine.

The following features directly correspond to librdkafka features (i.e., flags you would pass to configure if you were compiling manually).

All features are disabled by default unless noted otherwise above. The build process is defined in build.rs.

Updating

To upgrade change the git submodule in librdkafka, check if new errors need to be added to helpers::primive_to_rd_kafka_resp_err_t and update the version in Cargo.toml.