Consistent Hashing library for Rust
```rust extern crate hash_ring;
use hashring::HashRing; use hashring::NodeInfo;
fn main() {
let mut nodes: Vec
let mut hash_ring: HashRing<NodeInfo> = HashRing::new(nodes, 10);
println!(
"Key: '{}', Node: {}",
"hello",
hash_ring.get_node(("hello").to_string()).unwrap()
);
println!(
"Key: '{}', Node: {}",
"dude",
hash_ring.get_node(("dude").to_string()).unwrap()
);
println!(
"Key: '{}', Node: {}",
"martian",
hash_ring.get_node(("martian").to_string()).unwrap()
);
println!(
"Key: '{}', Node: {}",
"tardis",
hash_ring.get_node(("tardis").to_string()).unwrap()
);
hash_ring.remove_node(&NodeInfo {
host: "localhost",
port: 15329,
});
println!(
"Key: '{}', Node: {}",
"hello",
hash_ring.get_node(("hello").to_string()).unwrap()
);
hash_ring.add_node(&NodeInfo {
host: "localhost",
port: 15329,
});
println!(
"Key: '{}', Node: {}",
"hello",
hash_ring.get_node(("hello").to_string()).unwrap()
);
} ```
For an example of how to use a custom hash function you can look at examples/custom_hasher.rs
Just fork it, implement your changes and submit a pull request.
MIT