The Go language implementation of gRPC. HTTP/2 based RPC
Go to file
Menghan Li f4273b1bc8
binarylog: fix racy TestClientBinaryLogCancel (#2423)
2018-11-01 10:20:23 -07:00
.github Add lock.yml for locking closed, stale PRs/issues (#2331) 2018-09-25 14:15:54 -07:00
Documentation documentation: add proxy doc (#2357) 2018-10-18 13:09:24 -07:00
balancer grpclb: downgrade error logs to warning (#2381) 2018-10-17 14:44:02 -07:00
benchmark Remove shadowing of built-ins (#2290) 2018-09-05 09:05:40 -07:00
binarylog/grpc_binarylog_v1 binarylog: implement methodlogger (#2334) 2018-10-18 17:27:11 -07:00
channelz channelz: update generated proto stubs 2018-10-29 16:33:56 -07:00
codes codes: fix: marshal/unmarshal a Code to JSON fails (#2116) 2018-06-01 10:56:55 -07:00
connectivity Add and use connectivity package for states (#1430) 2017-08-09 10:31:12 -07:00
credentials internal: update proto generated code (#2386) 2018-10-18 15:45:22 -07:00
encoding Revert "Less mem (#1987)" (#2049) 2018-05-03 11:37:59 -07:00
examples internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
grpclog Fix "deprecated" function godoc comments to match standard formatting (#2027) 2018-05-02 08:52:49 -07:00
health health: Checks if the service's serving status has changed before sending an update (#2424) 2018-10-31 15:45:18 -07:00
internal binarylog: fix racy TestClientBinaryLogCancel (#2423) 2018-11-01 10:20:23 -07:00
interop Provide a fake grpclb balancer server that can be used for testing (#2338) 2018-10-02 18:26:40 -07:00
keepalive keepalive: godoc improvement and behavior explanation (#2342) 2018-10-02 13:03:51 -07:00
metadata Remove shadowing of built-ins (#2290) 2018-09-05 09:05:40 -07:00
naming Fix typos (#1994) 2018-04-16 10:03:02 -07:00
peer autofix license notice 2017-06-08 14:42:19 +02:00
reflection go generate: update proto files (#2236) 2018-07-25 11:40:12 -07:00
resolver resolver/dns: support custom dns authority (#2265) 2018-09-25 10:45:03 -07:00
stats Remove unused symbols (#2287) 2018-09-05 12:29:02 -07:00
status Transport refactor (#2305) 2018-09-20 15:45:40 -07:00
stress go generate: update proto files (#2236) 2018-07-25 11:40:12 -07:00
tap Update ServerInHandle comments (#1437) 2017-08-14 10:05:02 -07:00
test Fixes a broken test case. (#2425) 2018-10-31 16:29:11 -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: remove Go 1.6 and 1.8 tests (#2415) 2018-11-01 08:50:05 -07:00
AUTHORS add AUTHORS and LICENSE 2017-06-08 14:37:28 +02:00
CONTRIBUTING.md documentation: add instructions for running tests locally (#2006) 2018-04-19 17:17:21 -07:00
LICENSE Make Apache 2.0 LICENSE file a verbatim copy (#1329) 2017-06-21 10:20:47 -07:00
Makefile Transport refactor (#2305) 2018-09-20 15:45:40 -07:00
README.md doc: add faq for logging and "transport is closing" error (#2372) 2018-10-15 13:28:48 -07:00
backoff.go internal: move backoff to internal (#2141) 2018-06-13 16:07:37 -07:00
balancer.go Remove unused symbols (#2287) 2018-09-05 12:29:02 -07:00
balancer_conn_wrappers.go credentials: support google default creds (#2315) 2018-09-25 13:17:25 -07:00
balancer_switching_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
balancer_test.go Remove unused symbols (#2287) 2018-09-05 12:29:02 -07:00
balancer_v1_wrapper.go Split grpclb out of top level grpc package (#2107) 2018-06-05 09:54:12 -07:00
call.go client: Implement gRFC A6: configurable client-side retry support (#2111) 2018-06-27 16:18:41 -07:00
call_test.go transport: move to internal to make room for new, public transport API (#2212) 2018-07-11 11:22:45 -07:00
clientconn.go internal: transport nil should happen before backoff (#2392) 2018-10-22 13:57:57 -07:00
clientconn_state_transition_test.go internal: fix client send preface problems (#2380) 2018-10-18 14:31:34 -07:00
clientconn_test.go internal: fix client send preface problems (#2380) 2018-10-18 14:31:34 -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 encoding: Introduce new method for registering and choosing codecs (#1813) 2018-01-23 11:39:40 -08:00
codegen.sh FIX: use /usr/bin/env bash in shebang 2016-12-17 20:45:30 +01:00
dialoptions.go credentials: support google default creds (#2315) 2018-09-25 13:17:25 -07:00
doc.go Fix missing and wrong license (#1422) 2017-08-04 13:46:18 -07:00
go.mod internal: update golint to use new url (#2393) 2018-10-31 14:39:18 -06:00
go.sum internal: update golint to use new url (#2393) 2018-10-31 14:39:18 -06:00
go16.go transport: eliminate StreamError; use status errors instead (#2239) 2018-07-26 10:30:58 -07:00
go17.go transport: eliminate StreamError; use status errors instead (#2239) 2018-07-26 10:30:58 -07:00
install_gae.sh testing: upgrade appengine sdk to version 1.9.68 (#2311) 2018-09-18 10:42:17 -07:00
interceptor.go server: Convert all non-status errors to codes.Unknown (#1881) 2018-03-08 13:46:26 -08:00
picker_wrapper.go transport: move to internal to make room for new, public transport API (#2212) 2018-07-11 11:22:45 -07:00
picker_wrapper_test.go transport: move to internal to make room for new, public transport API (#2212) 2018-07-11 11:22:45 -07:00
pickfirst.go channelz: channel tracing (#2262) 2018-09-12 11:15:32 -07:00
pickfirst_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
proxy.go Re-add support for Go1.6 (#1603) 2017-10-20 12:05:20 -07:00
proxy_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
resolver_conn_wrapper.go channelz: channel tracing (#2262) 2018-09-12 11:15:32 -07:00
resolver_conn_wrapper_test.go tests: fix leak in TestDialParseTargetUnknownScheme (#2320) 2018-09-27 13:50:06 -07:00
rpc_util.go binarylog: call binary log in Client and Server (#2388) 2018-10-31 10:21:20 -07:00
rpc_util_test.go transport: eliminate StreamError; use status errors instead (#2239) 2018-07-26 10:30:58 -07:00
server.go binarylog: call binary log in Client and Server (#2388) 2018-10-31 10:21:20 -07:00
server_test.go transport: move to internal to make room for new, public transport API (#2212) 2018-07-11 11:22:45 -07:00
service_config.go service config: Avoid logging a warning on empty serviceconfig. (#2316) 2018-10-04 13:25:25 -07:00
service_config_test.go Change parseTimeout to not handle non-second durations (#1706) 2017-12-05 10:04:04 -08:00
stream.go binarylog: call binary log in Client and Server (#2388) 2018-10-31 10:21:20 -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.17.0-dev (#2399) 2018-10-23 11:07:38 -07:00
vet.sh internal: update golint to use new url (#2393) 2018-10-31 14:39:18 -06: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

This requires Go 1.6 or later. Go 1.7 will be required soon.

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.