gRPC-rs

gRPC-rs is a Rust wrapper of gRPC Core. gRPC is a high performance, open source universal RPC framework that puts mobile and HTTP/2 first.

Crates.io docs.rs Build Status Build status

Status

This project is still under development. The following features with the check marks are supported:

Prerequisites

For Linux and MacOS, you also need to install gcc (or clang) too.

For Windows, you also need to install following software:

Build

$ cargo build

Usage

To generate the sources from proto files:

Option 1 - Manual Generation

  1. Install the protobuf compiler:

$ cargo install protobuf

  1. Install the gRPC compiler:

$ cargo install grpcio-compiler

  1. Generate the sources:

$ protoc --rust_out=. --grpc_out=. --plugin=protoc-gen-grpc=`which grpc_rust_plugin` example.proto

To include this project as a dependency:

[dependencies] grpcio = "0.2"

Option 2 - Programmatic Generation

Programmatic generation can be used to generate Rust modules from proto files via your build.rs by using protoc-grpcio.

For more information and examples see the README.

Performance

See benchmark to find out how to run a benchmark by yourself.