drpc

package module
v0.0.22 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 14, 2021 License: MIT Imports: 3 Imported by: 104

README

DRPC

A drop-in, lightweight gRPC replacement.

Go Report Card Go Doc Beta

Highlights

  • Simple, at just a few thousands lines of code!
  • Compatible. Works for many gRPC use-cases as-is!
  • Fast. DRPC has a lightning quick wire format
  • Extensible. DRPC is transport agnostic, supports middleware, and is designed around interfaces.
  • Battle Tested. Already used in production for years across tens of thousands of servers.

Benchmarks

These microbenchmarks attempt to provide a comparison and come with some caveats. First, gRPC and DRPC have different flushing semantics when sending messages. Specifically, gRPC will buffer for some period whereas DRPC always immediately flushes. This difference is most apparent in the Input/Output Stream benchmarks under the Small and Medium sizes. Second, all microbenchmarks are flawed. These, in particular, do not even send data over a network connection. Third, no attempt was made to do the benchmarks in a controlled environment (CPU scaling disabled, noiseless, etc.).

Benchmark Measure Small Medium Large
gRPCDRPCdelta gRPCDRPCdelta gRPCDRPCdelta
Unitary time/op 39.5µs17.1µs-56.64% 39.7µs21.5µs-45.83% 1.35ms0.65ms-52.07%
speed 53.8kB/s120.0kB/s+123.26% 51.7MB/s95.4MB/s+84.48% 775MB/s1618MB/s+108.64%
mem/op 8.43kB2.05kB-75.65% 21.9kB8.5kB-61.43% 6.51MB3.22MB-50.44%
allocs/op 16920-88.17% 17122-87.13% 42223-94.64%
Input Stream time/op 856ns2501ns+192.29% 2.95µs3.37µs+14.09% 544µs263µs-51.73%
speed 2.28MB/s0.80MB/s-64.91% 696MB/s610MB/s-12.35% 1.93GB/s3.99GB/s+107.18%
mem/op 409B80B-80.46% 7.09kB2.13kB-69.99% 3.22MB1.08MB-66.39%
allocs/op 111-90.91% 122-83.33% 1282-98.44%
Output Stream time/op 953ns2585µs+171.35% 2.87µs3.49µs+21.56% 532µs247µs-53.50%
speed 4.20MB/s1.55MB/s-63.15% 716MB/s589MB/s-17.74% 1.97GB/s4.24GB/s+115.02%
mem/op 371B160B-56.89% 7.06kB2.21kB-68.75% 3.21MB1.06MB-66.98%
allocs/op 112-80.00% 113-72.73% 1313-97.70%
Bidir Stream time/op 10.7µs5.3µs-50.67 15.9µs7.2µs-54.36% 1.38ms0.61ms-55.79%
speed 185kB/s379kB/s+104.63% 129MB/s284MB/s+119.11% 761MB/s1659MB/s+117.91%
mem/op 1.02kB0.24kB-76.44% 14.5kB4.3kB-69.99% 6.52MB2.17MB-66.66%
allocs/op 413-92.68% 445-88.64% 2916-98.07%

Licensing

DRPC is licensed under the MIT/expat license. See the LICENSE file for more.

Documentation

Overview

Package drpc is a light replacement for gprc.

Index

Constants

This section is empty.

Variables

View Source
var (
	Error         = errs.Class("drpc")
	InternalError = errs.Class("internal error")
	ProtocolError = errs.Class("protocol error")
	ClosedError   = errs.Class("closed")
)

These error classes represent some common errors that drpc generates.

Functions

This section is empty.

Types

type Conn

type Conn interface {
	// Close closes the connection.
	Close() error

	// Closed returns true if the connection is definitely closed.
	Closed() bool

	// Transport returns the transport the connection is using.
	Transport() Transport

	// Invoke issues a unary RPC to the remote. Only one Invoke or Stream may be
	// open at once.
	Invoke(ctx context.Context, rpc string, enc Encoding, in, out Message) error

	// NewStream starts a stream with the remote. Only one Invoke or Stream may be
	// open at once.
	NewStream(ctx context.Context, rpc string, enc Encoding) (Stream, error)
}

Conn represents a client connection to a server.

type Description

type Description interface {
	// NumMethods returns the number of methods available.
	NumMethods() int

	// Method returns the information about the nth method along with a handler
	// to invoke it. The method interface that it returns is expected to be
	// a method expression like `(*Type).HandlerName`.
	Method(n int) (rpc string, encoding Encoding, receiver Receiver, method interface{}, ok bool)
}

Description is the interface implemented by things that can be registered by a Server.

type Encoding added in v0.0.18

type Encoding interface {
	// Marshal returns the encoded form of msg.
	Marshal(msg Message) ([]byte, error)

	// Unmarshal reads the encoded form of some Message into msg.
	// The buf is expected to contain only a single complete Message.
	Unmarshal(buf []byte, msg Message) error
}

Encoding represents a way to marshal/unmarshal Message types.

type Handler

type Handler interface {
	// HandleRPC executes the RPC identified by the rpc string using the stream to
	// communicate with the remote.
	HandleRPC(stream Stream, rpc string) (err error)
}

Handler handles streams and RPCs dispatched to it by a Server.

type Message

type Message interface{}

Message is a protobuf message. It is expected to be used with an Encoding. This exists so that one can use whatever protobuf library/runtime they want.

type Mux added in v0.0.10

type Mux interface {
	// Register marks that the description should dispatch RPCs that it describes to
	// the provided srv.
	Register(srv interface{}, desc Description) error
}

Mux is a type that can have an implementation and a Description registered with it.

type Receiver added in v0.0.10

type Receiver = func(srv interface{}, ctx context.Context, in1, in2 interface{}) (out Message, err error)

Receiver is invoked by a server for a given RPC.

type Stream

type Stream interface {
	// Context returns the context associated with the stream. It is canceled
	// when the Stream is closed and no more messages will ever be sent or
	// received on it.
	Context() context.Context

	// MsgSend sends the Message to the remote.
	MsgSend(msg Message, enc Encoding) error

	// MsgRecv receives a Message from the remote.
	MsgRecv(msg Message, enc Encoding) error

	// CloseSend signals to the remote that we will no longer send any messages.
	CloseSend() error

	// Close closes the stream.
	Close() error
}

Stream is a bi-directional stream of messages to some other party.

type Transport

type Transport interface {
	io.Reader
	io.Writer
	io.Closer
}

Transport is an interface describing what is required for a drpc connection.

Directories

Path Synopsis
cmd
Package drpccache implements per stream cache for drpc.
Package drpccache implements per stream cache for drpc.
Package drpcconn creates a drpc client connection from a transport.
Package drpcconn creates a drpc client connection from a transport.
Package drpcctx has helpers to interact with context.Context.
Package drpcctx has helpers to interact with context.Context.
Package drpcdebug provides helpers for debugging.
Package drpcdebug provides helpers for debugging.
Package drpcenc holds some helper functions for encoding messages.
Package drpcenc holds some helper functions for encoding messages.
Package drpcerr lets one associate error codes with errors.
Package drpcerr lets one associate error codes with errors.
Package drpchttp implements a net/http handler for unitary RPCs.
Package drpchttp implements a net/http handler for unitary RPCs.
Package drpcmanager reads packets from a transport to make streams.
Package drpcmanager reads packets from a transport to make streams.
Package drpcmetadata define the structure of the metadata supported by drpc library.
Package drpcmetadata define the structure of the metadata supported by drpc library.
Package drpcmigrate provides tools to support drpc concurrently alongside gRPC on the same ports.
Package drpcmigrate provides tools to support drpc concurrently alongside gRPC on the same ports.
Package drpcmux is a handler to dispatch rpcs to implementations.
Package drpcmux is a handler to dispatch rpcs to implementations.
Package drpcserver allows one to execute registered rpcs.
Package drpcserver allows one to execute registered rpcs.
Package drpcsignal holds a helper type to signal errors.
Package drpcsignal holds a helper type to signal errors.
Package drpcstream sends protobufs using the dprc wire protocol.
Package drpcstream sends protobufs using the dprc wire protocol.
Package drpcwire provides low level helpers for the drpc wire protocol.
Package drpcwire provides low level helpers for the drpc wire protocol.
examples
drpc Module
drpc_and_http Module
grpc Module
grpc_and_drpc Module
opentelemetry Module
internal
fuzz-drpcwire
Package fuzz is used to fuzz drpcwire frame parsing.
Package fuzz is used to fuzz drpcwire frame parsing.
backcompat Module
grpccompat Module
integration Module
twirpcompat Module

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL