The Go language implementation of gRPC. HTTP/2 based RPC
Перейти к файлу
apolcyn 17f2449821 Add google_default_credentials interop test case for go (#2600)
Implementing the [google default creds](https://github.com/grpc/grpc/blob/master/doc/interop-test-descriptions.md#google_default_credentials) interop test for go.

This test case was added in https://github.com/grpc/grpc/pull/17213. The existing OAuth creds test cases turned out to not be great first for google default creds testing, so https://github.com/grpc/grpc/pull/17213 got rid of those tests and created a new dedicated test for google default creds. This PR does that and also gets rid of the now-unneeded (we thought they would be needed earlier) OAuth test scenarios with plain ALTS.
2019-01-29 11:49:49 -08:00
.github Add lock.yml for locking closed, stale PRs/issues (#2331) 2018-09-25 14:15:54 -07:00
Documentation examples: reflection (#2594) 2019-01-25 15:35:01 -08:00
balancer fix: typos (#2591) 2019-01-23 09:59:48 -08:00
benchmark benchmark: Unconstrained streaming benchmark (#2512) 2019-01-11 17:37:31 -08: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 TLS 1.3 cipher suites (#2596) 2019-01-25 08:47:38 -08:00
encoding Remove support for Go1.6-1.8 (#2428) 2018-11-01 15:43:42 -07:00
examples examples: reflection (#2594) 2019-01-25 15:35:01 -08:00
grpclog Fix "deprecated" function godoc comments to match standard formatting (#2027) 2018-05-02 08:52:49 -07:00
health health: resume health server (#2528) 2018-12-26 10:44:53 -08:00
internal cleanup: remove staticcheck exception (#2582) 2019-01-17 10:24:42 -08:00
interop Add google_default_credentials interop test case for go (#2600) 2019-01-29 11:49:49 -08:00
keepalive comment typo: MaxConnectionAgeGrace(#2515) 2018-12-09 23:18:17 -08:00
metadata cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
naming fix: typos (#2591) 2019-01-23 09:59:48 -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 fix: typos (#2591) 2019-01-23 09:59:48 -08:00
stats client: deprecates FailFast & replaces its use by WaitForReady. 2018-12-13 15:15:11 -08: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 credentials: add TLS 1.3 cipher suites (#2596) 2019-01-25 08:47:38 -08: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.12beta2 to CI (#2598) 2019-01-25 13:07:43 -08:00
AUTHORS
CONTRIBUTING.md documentation: add instructions for running tests locally (#2006) 2018-04-19 17:17:21 -07:00
LICENSE
Makefile Transport refactor (#2305) 2018-09-20 15:45:40 -07:00
README.md Remove support for Go1.6-1.8 (#2428) 2018-11-01 15:43:42 -07: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 grpclb: filter out grpclb addresses if balancer in use is not grpclb (#2509) 2018-12-13 10:54:42 -08:00
balancer_switching_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_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 plumb lastConn error in v1 balancer (#2508) 2018-12-07 09:12:49 -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 fix: typos (#2591) 2019-01-23 09:59:48 -08:00
clientconn_state_transition_test.go internal: split StateRecordingBalancer in test to balancer and builder (#2578) 2019-01-18 10:21:46 -08:00
clientconn_test.go internal: split StateRecordingBalancer in test to balancer and builder (#2578) 2019-01-18 10:21:46 -08:00
codec.go
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
dialoptions.go cleanup: use time.Until(t) instead of t.Sub(time.Now) (#2571) 2019-01-15 16:09:50 -08:00
doc.go
go.mod cleanup: update staticcheck to version supporting modules and new checkers (#2583) 2019-01-17 16:27:42 -08:00
go.sum cleanup: update staticcheck to version supporting modules and new checkers (#2583) 2019-01-17 16:27:42 -08: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 cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
picker_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
pickfirst.go cleanup: replace "x/net/context" import with "context" (#2439) 2018-11-12 13:30:41 -08:00
pickfirst_test.go grpctest: add new package to manage tests and support per-test setup/teardown (#2523) 2019-01-07 14:24:56 -08: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 internal: change split2() comment to be consistent with behavior (#2547) 2019-01-07 10:14:06 -08: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 rpc_util: update deprecated messages (#2545) 2019-01-07 13:45:27 -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 comment: default MaxSendMsgSize should be math.MaxInt32 instead of 4MB (#2586) 2019-01-22 10:48:59 -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 health: Client LB channel health checking (#2387) 2018-11-01 10:49:35 -07: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 cleanup: remove unused symbols (#2581) 2019-01-17 10:14:45 -08:00
trace.go
version.go Change version to 1.19.0-dev (#2569) 2019-01-15 13:34:07 -08:00
vet.sh cleanup: update staticcheck to version supporting modules and new checkers (#2583) 2019-01-17 16:27:42 -08: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.