mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 18:13:42 +08:00 
			
		
		
		
	full diff: - https://github.com/moby/buildkit/compare/20230620112432...v0.12.0 - https://github.com/moby/buildkit/compare/v0.12.0...faa0cc7da3536923d85b74b2bb2d13c12a6ecc99 Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
		
			
				
	
	
		
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# ttrpc
 | 
						|
 | 
						|
[](https://github.com/containerd/ttrpc/actions?query=workflow%3ACI)
 | 
						|
 | 
						|
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.
 | 
						|
 | 
						|
# Protocol
 | 
						|
 | 
						|
See the [protocol specification](./PROTOCOL.md).
 | 
						|
 | 
						|
# 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.
 | 
						|
 | 
						|
It's recommended to use [`protobuild`](https://github.com/containerd/protobuild)
 | 
						|
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.
 | 
						|
 | 
						|
# Status
 | 
						|
 | 
						|
TODO:
 | 
						|
 | 
						|
- [ ] Add testing under concurrent load to ensure
 | 
						|
- [ ] Verify connection error handling
 | 
						|
 | 
						|
# 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:
 | 
						|
 * [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)
 | 
						|
 | 
						|
information in our [`containerd/project`](https://github.com/containerd/project) repository.
 |