tonic

A native gRPC client & server implementation with async/await support.

Github星跟蹤圖

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.

Crates.io
Documentation
Crates.io

Examples, Website, Docs, Chat

Overview

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.

Features

  • Bi-directional streaming
  • High performance async io
  • Interoperability
  • TLS backed by rustls
  • Load balancing
  • Custom metadata
  • Authentication

Getting Started

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.

Rust Version

tonic currently works on rust 1.39 and above as it requires support for the async_await
feature.

$ rustup update
$ rustup component add rustfmt
$ cargo build

Tutorials

  • The helloworld tutorial provides a basic example of using tonic, perfect for first time users!
  • The routeguide tutorial provides a complete example of using tonic and all its
    features.

Getting Help

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.

Project Layout

  • tonic: Generic gRPC and HTTP/2 client/server
    implementation.
  • tonic-build: prost based service codegen.
  • examples: Example gRPC implementations showing off
    tls, load balancing and bi-directional streaming.
  • interop: Interop tests implementation.

Contributing

: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.

License

This project is licensed under the MIT license.

Contribution

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.

主要指標

概覽
名稱與所有者hyperium/tonic
主編程語言Rust
編程語言Rust (語言數: 4)
平台
許可證MIT License
所有者活动
創建於2019-08-09 17:59:37
推送於2025-05-02 03:01:52
最后一次提交2025-05-01 21:49:48
發布數41
最新版本名稱v0.13.0 (發布於 )
第一版名稱v0.1.0-alpha.2 (發布於 )
用户参与
星數10.8k
關注者數78
派生數1.1k
提交數1.2k
已啟用問題?
問題數859
打開的問題數249
拉請求數1061
打開的拉請求數39
關閉的拉請求數141
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?