The Go language implementation of gRPC. HTTP/2 based RPC
Go to file
apolcyn 6d8271a06c credentials: add compute engine channel creds (#2708) 2019-03-25 14:47:12 -07:00
.github update to use new fancy issue templates (#2712) 2019-03-22 10:50:40 -07:00
Documentation doc: fix typos (#2655) 2019-02-25 10:31:22 -08:00
balancer bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
benchmark benchmark: exit after printing help when using `-h` (#2701) 2019-03-21 12:04:35 -07:00
binarylog/grpc_binarylog_v1 binarylog: implement methodlogger (#2334) 2018-10-18 17:27:11 -07:00
channelz channelz: Implement GetServer method for channelz (#2537) 2019-01-09 10:50:34 -08:00
codes codes: fix: marshal/unmarshal a Code to JSON fails (#2116) 2018-06-01 10:56:55 -07:00
connectivity fix: typos (#2591) 2019-01-23 09:59:48 -08:00
credentials credentials: add compute engine channel creds (#2708) 2019-03-25 14:47:12 -07:00
encoding encoding: check whether encoding.Name() is empty before calling strings.ToLower (#2707) 2019-03-22 13:34:43 -07:00
examples bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
grpclog Downgrade grpclb package info logs to V(2). (#2710) 2019-03-22 10:11:37 -07:00
health health: resume health server (#2528) 2018-12-26 10:44:53 -08:00
internal cleanup: remove unnecessary ignoreContentType field (#2715) 2019-03-22 13:56:18 -07:00
interop credentials: add compute engine channel creds (#2708) 2019-03-25 14:47:12 -07:00
keepalive keepalive: apply minimum ping time of 10s to client and 1s to server (#2642) 2019-02-21 13:09:37 -08:00
metadata cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
naming Fix typo s/banlacer/balancer/ (#2633) 2019-02-11 09:46:38 -08:00
peer cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
reflection client: deprecates FailFast & replaces its use by WaitForReady. 2018-12-13 15:15:11 -08:00
resolver bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
stats stats: add Trailer to client-side stats.End (#2639) 2019-03-13 10:10:52 -07:00
status Remove support for Go1.6-1.8 (#2428) 2018-11-01 15:43:42 -07:00
stress client: deprecates FailFast & replaces its use by WaitForReady. 2018-12-13 15:15:11 -08:00
tap cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
test bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
testdata testdata: get test assets related to package root instead of GOPATH (#2272) 2018-08-22 09:00:39 -07:00
.travis.yml travis: add Go 1.12.x to CI (#2671) 2019-03-07 13:31:25 -08:00
AUTHORS add AUTHORS and LICENSE 2017-06-08 14:37:28 +02:00
CONTRIBUTING.md makefile: remove testappengine from make all (#2621) 2019-02-07 13:44:42 -08:00
LICENSE Make Apache 2.0 LICENSE file a verbatim copy (#1329) 2017-06-21 10:20:47 -07:00
Makefile makefile: remove testappengine from make all (#2621) 2019-02-07 13:44:42 -08:00
README.md Fix styling (#2647) 2019-02-21 16:37:37 -08:00
backoff.go fix: typos (#2591) 2019-01-23 09:59:48 -08:00
balancer.go cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
balancer_conn_wrappers.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
balancer_switching_test.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
balancer_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
balancer_v1_wrapper.go client: clean up v1 balancer wrapper error handling (#2511) 2019-01-30 10:56:23 -08:00
call.go fix: typos (#2591) 2019-01-23 09:59:48 -08:00
call_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
clientconn.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
clientconn_state_transition_test.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
clientconn_test.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
codec.go encoding: Introduce new method for registering and choosing codecs (#1813) 2018-01-23 11:39:40 -08:00
codec_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
codegen.sh FIX: use /usr/bin/env bash in shebang 2016-12-17 20:45:30 +01:00
dialoptions.go internal: fix Dial_OneBackoffPerRetryGroup (#2689) 2019-03-20 13:58:29 -06:00
doc.go Fix missing and wrong license (#1422) 2017-08-04 13:46:18 -07:00
go.mod internal: update x/lint dependency (#2690) 2019-03-14 14:38:41 -06:00
go.sum internal: update x/lint dependency (#2690) 2019-03-14 14:38:41 -06:00
grpc_test.go test: disable leakcheck after the first failure (#2563) 2019-01-14 15:40:20 -08:00
install_gae.sh testing: upgrade appengine sdk to version 1.9.68 (#2311) 2018-09-18 10:42:17 -07:00
interceptor.go cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
picker_wrapper.go balancer: make sure non-nil done returned by Pick is called (#2688) 2019-03-19 10:47:09 -07:00
picker_wrapper_test.go Fix error formatting based on best practices from Code Review Comments (#2615) 2019-02-07 10:01:40 -08:00
pickfirst.go cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
pickfirst_test.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
proxy.go proxy: support basic authentication (#2426) 2018-11-13 14:59:16 -08:00
proxy_test.go cleanup: use time.Until(t) instead of t.Sub(time.Now) (#2571) 2019-01-15 16:09:50 -08:00
resolver_conn_wrapper.go bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00
resolver_conn_wrapper_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
rpc_util.go grpc: limit reader with maxReceiveMessageSize (#2617) 2019-02-07 13:32:00 -08:00
rpc_util_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
server.go server: Don't log errors on ErrConnDispatched (#2656) 2019-03-07 13:22:17 -08:00
server_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
service_config.go service config: make retryThrottling maxTokens setting of 1000 valid (#2670) 2019-03-07 14:30:57 -08:00
service_config_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08:00
stream.go stats: add Trailer to client-side stats.End (#2639) 2019-03-13 10:10:52 -07:00
trace.go Truncate payload trace string, and turn trace off by default (#1509) 2017-09-08 11:13:41 -07:00
version.go Change version to 1.20.0-dev (#2661) 2019-02-26 11:34:33 -08:00
vet.sh bar: add ability to update resolver state atomically and pass directly to the balancer (#2693) 2019-03-22 10:48:55 -07:00

README.md

gRPC-Go

Build Status GoDoc GoReportCard

The Go implementation of gRPC: A high performance, open source, general RPC framework that puts mobile and HTTP/2 first. For more information see the gRPC Quick Start: Go guide.

Installation

To install this package, you need to install Go and setup your Go workspace on your computer. The simplest way to install the library is to run:

$ go get -u google.golang.org/grpc

Prerequisites

gRPC-Go requires Go 1.9 or later.

Constraints

The grpc package should only depend on standard Go packages and a small number of exceptions. If your contribution introduces new dependencies which are NOT in the list, you need a discussion with gRPC-Go authors and consultants.

Documentation

See API documentation for package and API descriptions and find examples in the examples directory.

Performance

See the current benchmarks for some of the languages supported in this dashboard.

Status

General Availability Google Cloud Platform Launch Stages.

FAQ

Compiling error, undefined: grpc.SupportPackageIsVersion

Please update proto package, gRPC package and rebuild the proto files:

  • go get -u github.com/golang/protobuf/{proto,protoc-gen-go}
  • go get -u google.golang.org/grpc
  • protoc --go_out=plugins=grpc:. *.proto

How to turn on logging

The default logger is controlled by the environment variables. Turn everything on by setting:

GRPC_GO_LOG_VERBOSITY_LEVEL=99 GRPC_GO_LOG_SEVERITY_LEVEL=info

The RPC failed with error "code = Unavailable desc = transport is closing"

This error means the connection the RPC is using was closed, and there are many possible reasons, including:

  1. mis-configured transport credentials, connection failed on handshaking
  2. bytes disrupted, possibly by a proxy in between
  3. server shutdown

It can be tricky to debug this because the error happens on the client side but the root cause of the connection being closed is on the server side. Turn on logging on both client and server, and see if there are any transport errors.