A rust implementation of [gRPC], a high performance, open source, general RPC framework that puts mobile and HTTP/2 first.
[tonic
] is a gRPC over HTTP/2 implementation focused on high performance, interoperability, and flexibility. This library was created to have first class support of async/await and to act as a core building block for production systems written in Rust.
[Examples] | [Website] | [Docs] | [Chat]
[tonic
] is composed of three main components: the generic gRPC implementation, the high performance HTTP/2
implementation and the codegen powered by [prost
]. The generic implementation can support any HTTP/2
implementation and any encoding via a set of generic traits. The HTTP/2 implementation is based on [hyper
],
a fast HTTP/1.1 and HTTP/2 client and server built on top of the robust [tokio
] stack. The codegen
contains the tools to build clients and servers from [protobuf
] definitions.
rustls
]Examples can be found in [examples
] and for more complex scenarios [interop
]
may be a good resource as it shows examples of many of the gRPC features.
If you're using [rust-analyzer] we recommend you set "rust-analyzer.cargo.buildScripts.enable": true
to correctly load
the generated code.
For IntelliJ IDEA users, please refer to this and enable
org.rust.cargo.evaluate.build.scripts
experimental feature.
tonic
's MSRV is 1.64
.
bash
$ rustup update
$ cargo build
In order to build tonic
>= 0.8.0, you need the protoc
Protocol Buffers compiler, along with Protocol Buffers resource files.
bash
sudo apt update && sudo apt upgrade -y
sudo apt install -y protobuf-compiler libprotobuf-dev
sh
sudo apk add protoc protobuf-dev
Assuming Homebrew is already installed. (If not, see instructions for installing Homebrew on the Homebrew website.)
zsh
brew install protobuf
protoc-xx.y-win64.zip
from HEREbin\protoc.exe
and put it somewhere in the PATH
protoc --version
helloworld
tutorial provides a basic example of using tonic
, perfect for first time users!routeguide
tutorial provides a complete example of using tonic
and all its
features.First, see if the answer to your question can be found in the API documentation. If the answer is not there, there is an active community in the Tonic Discord channel. We would be happy to try to answer your question. If that doesn't work, try opening an [issue] with the question.
tonic
: Generic gRPC and HTTP/2 client/server
implementation.tonic-build
: [prost
] based service codegen.tonic-types
: [prost
] based grpc utility types
including support for gRPC Well Known Types.tonic-health
: Implementation of the standard gRPC
health checking service. Also serves as an example of both unary and response streaming.tonic-reflection
: A tonic based gRPC
reflection implementation.examples
: Example gRPC implementations showing off
tls, load balancing and bi-directional streaming.interop
: Interop tests implementation.:balloon: Thanks for your help improving the project! We are so happy to have you! We have a contributing guide to help you get involved in the Tonic project.
This project is licensed under the MIT license.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Tonic by you, shall be licensed as MIT, without any additional terms or conditions.