bumping google.golang.org/grpc 577eb69...f74f033: > f74f033 Change version to 1.36.0 (# 4198) > e6d71ad encoding/proto: do not panic when types do not match (# 4218) (# 4223) > 61962d0 status: document nil error handling of FromError (# 4196) > 9280052 balancergroup: Propagate balancer.BuildOptions to child policies (# 4184) > b753f49 xds testing: increase timeout from 90 minutes to 120 minutes (# 4191) > 7b8d65a xds: rename internal/client files to remove client prefix (# 4188) > f005af0 examples: delete profiling example since profiling support was rolled back (# 4182) > 0bc7417 xds: report drops by circuit breaking (# 4171) > e526a29 xds: Remove v3Support environment variable (# 4174) > 7bb497f grpc: Update protobuf regenrate script (# 4177) > 2c42474 pemfile: Make test happy with Go1.16 (# 4164) > 7f2581f xds interop: add xds v3 kokoro tests (# 4165) > f579b61 test: Run e2e authority tests only on linux. (# 4160) > 504caa9 interop/xds: support ClientConfigureRequest.timeout_sec field (# 4157) > 269d253 interop/xds: implement new stats response field (# 4156) > ef9850d xds bootstrap: support config content in env variable (# 4153) > 938f6e2 cmd/protoc-gen-go-grpc: add gRPC-Go version comment and update release version (# 4152) > 5e3cbb5 interop/grpc_testing: update generated code after recent grpc-proto changes (# 4149) > d3ae124 cleanup: use different import alias for services than messages (# 4148) > 4cf4a98 Change version to 1.36.0-dev (# 4142) bumping knative.dev/net-istio 59b2af9...f9ffb01: > f9ffb01 Add an accessor for DestinationRule objects (# 558) > b224102 Update common github actions (# 556) > 3214fb4 upgrade to latest dependencies (# 557) > 3a9a02e Add configuration for graceful shutdown to ingressgateways (# 553) > 2308c2f Update Istio stable to 1.8.4. (# 550) > c53089b Use prefix matching for KIngress rule paths (# 541) > f73a33d Add a feature flag to guard pod addressability additions (# 545) > f3bad87 Add the reconciler machinery for pod addressability (# 546) > 4e84c36 upgrade to latest dependencies (# 548) > 8f2d8cd upgrade to latest dependencies (# 544) > e72872d Update common github actions (# 547) > ad2b7bb upgrade to latest dependencies (# 540) > fb452f3 Update common github actions (# 538) > fee4721 Drop master references to knative repos (# 539) > 64b9467 Run all actions against main (# 537) > 4d2d0eb upgrade to latest dependencies (# 536) > eebb4e6 Handle the case when ingress name has dot (# 532) > 1f5e664 Update Istio latest to 1.9.1. (# 535) > 6ef3289 upgrade to latest dependencies (# 534) > fe7d984 upgrade to latest dependencies (# 529) > 212691e Consolidate lines in CODEOWNERS, drop hack/test (# 531) > 713aacd upgrade to latest dependencies (# 528) > 9bfac14 Bump k8s version in kind e2e (# 526) bumping knative.dev/hack 8368e1f...9b73a25: > 9b73a25 Drop unnecessary occurrences of master (# 53) > f99a255 Schema tool for reflective schema generation. (# 51) Signed-off-by: Knative Automation <automation@knative.team> |
||
---|---|---|
.. | ||
attributes | ||
backoff | ||
balancer | ||
binarylog/grpc_binarylog_v1 | ||
codes | ||
connectivity | ||
credentials | ||
encoding | ||
grpclog | ||
internal | ||
keepalive | ||
metadata | ||
peer | ||
reflection | ||
resolver | ||
serviceconfig | ||
stats | ||
status | ||
tap | ||
.travis.yml | ||
AUTHORS | ||
CODE-OF-CONDUCT.md | ||
CONTRIBUTING.md | ||
GOVERNANCE.md | ||
LICENSE | ||
MAINTAINERS.md | ||
Makefile | ||
README.md | ||
SECURITY.md | ||
backoff.go | ||
balancer_conn_wrappers.go | ||
call.go | ||
clientconn.go | ||
codec.go | ||
codegen.sh | ||
dialoptions.go | ||
doc.go | ||
go.mod | ||
go.sum | ||
install_gae.sh | ||
interceptor.go | ||
picker_wrapper.go | ||
pickfirst.go | ||
preloader.go | ||
regenerate.sh | ||
resolver_conn_wrapper.go | ||
rpc_util.go | ||
server.go | ||
service_config.go | ||
stream.go | ||
trace.go | ||
version.go | ||
vet.sh |
README.md
gRPC-Go
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 Go gRPC docs, or jump directly into the quick start.
Prerequisites
Installation
With Go module support (Go 1.11+), simply add the following import
import "google.golang.org/grpc"
to your code, and then go [build|run|test]
will automatically fetch the
necessary dependencies.
Otherwise, to install the grpc-go
package, run the following command:
$ go get -u google.golang.org/grpc
Note: If you are trying to access
grpc-go
from China, see the FAQ below.
Learn more
- Go gRPC docs, which include a quick start and API reference among other resources
- Low-level technical docs from this repository
- Performance benchmark
- Examples
FAQ
I/O Timeout Errors
The golang.org
domain may be blocked from some countries. go get
usually
produces an error like the following when this happens:
$ go get -u google.golang.org/grpc
package google.golang.org/grpc: unrecognized import path "google.golang.org/grpc" (https fetch: Get https://google.golang.org/grpc?go-get=1: dial tcp 216.239.37.1:443: i/o timeout)
To build Go code, there are several options:
-
Set up a VPN and access google.golang.org through that.
-
Without Go module support:
git clone
the repo manually:git clone https://github.com/grpc/grpc-go.git $GOPATH/src/google.golang.org/grpc
You will need to do the same for all of grpc's dependencies in
golang.org
, e.g.golang.org/x/net
. -
With Go module support: it is possible to use the
replace
feature ofgo mod
to create aliases for golang.org packages. In your project's directory:go mod edit -replace=google.golang.org/grpc=github.com/grpc/grpc-go@latest go mod tidy go mod vendor go build -mod=vendor
Again, this will need to be done for all transitive dependencies hosted on golang.org as well. For details, refer to golang/go issue #28652.
Compiling error, undefined: grpc.SupportPackageIsVersion
If you are using Go modules:
Ensure your gRPC-Go version is require
d at the appropriate version in
the same module containing the generated .pb.go
files. For example,
SupportPackageIsVersion6
needs v1.27.0
, so in your go.mod
file:
module <your module name>
require (
google.golang.org/grpc v1.27.0
)
If you are not using Go modules:
Update the 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 environment variables. Turn everything on like this:
$ export GRPC_GO_LOG_VERBOSITY_LEVEL=99
$ export 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:
- mis-configured transport credentials, connection failed on handshaking
- bytes disrupted, possibly by a proxy in between
- server shutdown
- Keepalive parameters caused connection shutdown, for example if you have configured your server to terminate connections regularly to trigger DNS lookups. If this is the case, you may want to increase your MaxConnectionAgeGrace, to allow longer RPC calls to finish.
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.