ginepro
provides client-side gRPC load-balancing out of the box by enriching tonic
‘s channel with periodic service discovery.
ginepro
enriches tonic by periodically updating the list of
servers that are available through a ServiceDiscovery
interface that currently is implemented for DNS.
Add ginepro
to your dependencies
```toml [dependencies]
ginepro = "0.6.0" ```
The interface remains fairly the same as we implement all the logic for a drop-in replacement for
tonic's Channel
.
``rust
// Using the
LoadBalancedChannel`.
use ginepro::LoadBalancedChannel;
use ginepro::pb::tester_client::TesterClient;
// Build a load-balanced channel given a service name and a port. let loadbalancedchannel = LoadBalancedChannel::builder( ("my_hostname", 5000) ) .channel() .await .expect("failed to construct LoadBalancedChannel");
// Initialise a new gRPC client for the Test
service
// using the load-balanced channel as transport
let grpcclient = TesterClient::new(loadbalanced_channel);
```
For more examples, have a look at the examples directory.
Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.