20 releases

0.7.1 Jul 19, 2021
0.6.5 Jul 10, 2021
0.6.2 Mar 26, 2021
0.5.4 Oct 23, 2020
0.1.1 Mar 28, 2020

#4 in Authentication

Download history 242/week @ 2021-04-05 658/week @ 2021-04-12 696/week @ 2021-04-19 611/week @ 2021-04-26 1883/week @ 2021-05-03 1752/week @ 2021-05-10 1979/week @ 2021-05-17 2370/week @ 2021-05-24 2913/week @ 2021-05-31 2120/week @ 2021-06-07 1482/week @ 2021-06-14 2624/week @ 2021-06-21 1652/week @ 2021-06-28 1872/week @ 2021-07-05 2685/week @ 2021-07-12 1567/week @ 2021-07-19

8,276 downloads per month
Used in 3 crates

MIT license

215KB
5.5K SLoC

etcd-client

MIT licensed Minimum rustc version Crate API

An etcd v3 API client for Rust. It provides asynchronous client backed by tokio and tonic.

Features

  • etcd API v3
  • asynchronous

Supported APIs

  • KV
  • Watch
  • Lease
  • Auth
  • Maintenance
  • Cluster
  • Lock
  • Election

Usage

Add this to your Cargo.toml:

[dependencies]
etcd-client = "0.7"
tokio = { version = "1.0", features = ["full"] }

To get started using etcd-client:

use etcd_client::{Client, Error};

#[tokio::main]
async fn main() -> Result<(), Error> {
    let mut client = Client::connect(["localhost:2379"], None).await?;
    // put kv
    client.put("foo", "bar", None).await?;
    // get kv
    let resp = client.get("foo", None).await?;
    if let Some(kv) = resp.kvs().first() {
        println!("Get kv: {{{}: {}}}", kv.key_str()?, kv.value_str()?);
    }

    Ok(())
}

Examples

Examples can be found in examples.

Feature Flags

  • tls: Enables the rustls-based TLS connection. Not enabled by default.
  • tls-roots: Adds system trust roots to rustls-based TLS connection using the rustls-native-certs crate. Not enabled by default.
  • pub-response-field: Exposes structs used to create regular etcd-client responses including internal protobuf representations. Useful for mocking. Not enabled by default.

Test

We test this library with etcd 3.4.

Notes that we use a fixed etcd server URI (localhost:2379) to connect to etcd server.

Rust version requirements

The minimum supported version is 1.45. The current etcd-client version is not guaranteed to build on Rust versions earlier than the minimum supported version.

License

This project is licensed under the MIT license (LICENSE or http://opensource.org/licenses/MIT).

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in etcd-client by you, shall be licensed as MIT, without any additional terms or conditions.

Dependencies

~5–9.5MB
~162K SLoC