The Go language implementation of gRPC. HTTP/2 based RPC
Перейти к файлу
dfawley 2106e3b393
credentials: cleanup version-specific files (#2178)
2018-06-27 15:49:04 -07:00
.github
Documentation Revert stickiness (#2175) 2018-06-26 10:02:54 -07:00
balancer balancer/grpclb: update to latest lb proto (#2172) 2018-06-22 15:31:54 -07:00
benchmark internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
channelz Restrict channelz service test to x86 architecture (#2179) 2018-06-27 11:58:54 -07:00
codes codes: fix: marshal/unmarshal a Code to JSON fails (#2116) 2018-06-01 10:56:55 -07:00
connectivity
credentials credentials: cleanup version-specific files (#2178) 2018-06-27 15:49:04 -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 internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
internal channelz: stage 4 - add security and socket option info with appengine build tags (#2149) 2018-06-25 10:32:20 -07:00
interop interop: set dns as default scheme in interop client (#2165) 2018-06-20 12:19:01 -07:00
keepalive
metadata Fix "deprecated" function godoc comments to match standard formatting (#2027) 2018-05-02 08:52:49 -07:00
naming Fix typos (#1994) 2018-04-16 10:03:02 -07:00
peer
reflection internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
resolver resolver/dns: error if target ends with a colon instead of assuming the default port (#2150) 2018-06-22 15:23:03 -07:00
stats internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
status status: Introduce FromContextError convenience function (#2057) 2018-05-10 09:54:36 -07:00
stress internal: Update proto generated code (#2133) 2018-06-08 17:54:26 -07:00
tap
test client, server: update dial/server buffer options to support a "disable" setting (#2147) 2018-06-27 11:16:33 -07:00
testdata
transport client, server: update dial/server buffer options to support a "disable" setting (#2147) 2018-06-27 11:16:33 -07:00
.travis.yml testing: run test in simulated appengine environment (#2145) 2018-06-21 13:09:46 -07:00
AUTHORS
CONTRIBUTING.md documentation: add instructions for running tests locally (#2006) 2018-04-19 17:17:21 -07:00
LICENSE
Makefile testing: run test in simulated appengine environment (#2145) 2018-06-21 13:09:46 -07:00
README.md Correct Go 1.6 support policy (#1934) 2018-03-21 10:03:08 -07:00
backoff.go internal: move backoff to internal (#2141) 2018-06-13 16:07:37 -07:00
balancer.go Mark old balancer and naming APIs as deprecated (#1951) 2018-04-05 13:12:31 -07:00
balancer_conn_wrappers.go Fix typos (#1994) 2018-04-16 10:03:02 -07:00
balancer_switching_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
balancer_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -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: fix interceptors after recent cleanup (#2046) 2018-05-03 09:00:38 -07:00
call_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
clientconn.go client, server: update dial/server buffer options to support a "disable" setting (#2147) 2018-06-27 11:16:33 -07:00
clientconn_test.go internal: move backoff to internal (#2141) 2018-06-13 16:07:37 -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
doc.go
go16.go server: Convert all non-status errors to codes.Unknown (#1881) 2018-03-08 13:46:26 -08:00
go17.go server: Convert all non-status errors to codes.Unknown (#1881) 2018-03-08 13:46:26 -08:00
install_gae.sh testing: run test in simulated appengine environment (#2145) 2018-06-21 13:09:46 -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 Revert stickiness (#2175) 2018-06-26 10:02:54 -07:00
picker_wrapper_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
pickfirst.go Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08: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 resolver_conn_wrapper.go: fix minor typo (#2135) 2018-06-08 15:37:41 -07:00
resolver_conn_wrapper_test.go go vet: fix composite literal uses unkeyed fields (#2005) 2018-04-19 17:16:53 -07:00
rpc_util.go internal: move version to a separate file (#2080) 2018-05-16 10:32:41 -07:00
rpc_util_test.go split encode into three functions (#2058) 2018-05-11 13:47:10 -07:00
server.go client, server: update dial/server buffer options to support a "disable" setting (#2147) 2018-06-27 11:16:33 -07:00
server_test.go internal: move leakcheck to internal/ (#2129) 2018-06-07 16:57:56 -07:00
service_config.go Revert stickiness (#2175) 2018-06-26 10:02:54 -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 channelz: move APIs to internal except channelz service (#2157) 2018-06-18 17:59:08 -07:00
trace.go
version.go Change version to 1.14.0-dev (#2163) 2018-06-19 17:32:50 -07:00
vet.sh internal/grpcrand: New package for concurrency-safe randoms (#2106) 2018-05-29 09:06:35 -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

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