2017-11-29 18:52:16 -05:00
|
|
|
# ttrpc
|
|
|
|
|
2021-11-19 07:48:43 -05:00
|
|
|
[![Build Status](https://github.com/containerd/ttrpc/workflows/CI/badge.svg)](https://github.com/containerd/ttrpc/actions?query=workflow%3ACI)
|
|
|
|
[![codecov](https://codecov.io/gh/containerd/ttrpc/branch/main/graph/badge.svg)](https://codecov.io/gh/containerd/ttrpc)
|
2017-11-30 11:11:33 -05:00
|
|
|
|
2017-11-29 18:52:16 -05:00
|
|
|
GRPC for low-memory environments.
|
|
|
|
|
|
|
|
The existing grpc-go project requires a lot of memory overhead for importing
|
|
|
|
packages and at runtime. While this is great for many services with low density
|
|
|
|
requirements, this can be a problem when running a large number of services on
|
|
|
|
a single machine or on a machine with a small amount of memory.
|
|
|
|
|
|
|
|
Using the same GRPC definitions, this project reduces the binary size and
|
|
|
|
protocol overhead required. We do this by eliding the `net/http`, `net/http2`
|
|
|
|
and `grpc` package used by grpc replacing it with a lightweight framing
|
|
|
|
protocol. The result are smaller binaries that use less resident memory with
|
|
|
|
the same ease of use as GRPC.
|
|
|
|
|
|
|
|
Please note that while this project supports generating either end of the
|
|
|
|
protocol, the generated service definitions will be incompatible with regular
|
|
|
|
GRPC services, as they do not speak the same protocol.
|
|
|
|
|
|
|
|
# Usage
|
|
|
|
|
|
|
|
Create a gogo vanity binary (see
|
|
|
|
[`cmd/protoc-gen-gogottrpc/main.go`](cmd/protoc-gen-gogottrpc/main.go) for an
|
|
|
|
example with the ttrpc plugin enabled.
|
|
|
|
|
2018-07-06 17:43:49 -04:00
|
|
|
It's recommended to use [`protobuild`](https://github.com//stevvooe/protobuild)
|
2017-11-29 18:52:16 -05:00
|
|
|
to build the protobufs for this project, but this will work with protoc
|
|
|
|
directly, if required.
|
|
|
|
|
|
|
|
# Differences from GRPC
|
|
|
|
|
|
|
|
- The protocol stack has been replaced with a lighter protocol that doesn't
|
|
|
|
require http, http2 and tls.
|
|
|
|
- The client and server interface are identical whereas in GRPC there is a
|
|
|
|
client and server interface that are different.
|
|
|
|
- The Go stdlib context package is used instead.
|
|
|
|
- No support for streams yet.
|
|
|
|
|
|
|
|
# Status
|
|
|
|
|
|
|
|
TODO:
|
|
|
|
|
|
|
|
- [ ] Document protocol layout
|
|
|
|
- [ ] Add testing under concurrent load to ensure
|
|
|
|
- [ ] Verify connection error handling
|
2019-03-15 03:16:41 -04:00
|
|
|
|
|
|
|
# Project details
|
|
|
|
|
|
|
|
ttrpc is a containerd sub-project, licensed under the [Apache 2.0 license](./LICENSE).
|
|
|
|
As a containerd sub-project, you will find the:
|
2021-11-19 07:48:43 -05:00
|
|
|
* [Project governance](https://github.com/containerd/project/blob/main/GOVERNANCE.md),
|
|
|
|
* [Maintainers](https://github.com/containerd/project/blob/main/MAINTAINERS),
|
|
|
|
* and [Contributing guidelines](https://github.com/containerd/project/blob/main/CONTRIBUTING.md)
|
2019-03-15 03:16:41 -04:00
|
|
|
|
|
|
|
information in our [`containerd/project`](https://github.com/containerd/project) repository.
|