The Go language implementation of gRPC. HTTP/2 based RPC
Перейти к файлу
田欧 8a8ac82f1f update const order (#1770) 2018-01-04 15:44:29 -08:00
.github Create ISSUE_TEMPLATE 2017-05-30 20:03:09 -07:00
Documentation Add proper support for 'identity' encoding type (#1664) 2017-11-17 09:24:54 -08:00
balancer Notify parent ClientConn to re-resolve in grpclb (#1699) 2017-12-18 15:36:55 -08:00
benchmark compare atomic and mutex performance for incrementing/storing one variable (#1757) 2018-01-02 10:46:13 -08:00
codes update const order (#1770) 2018-01-04 15:44:29 -08:00
connectivity Add and use connectivity package for states (#1430) 2017-08-09 10:31:12 -07:00
credentials credentials: return Unavailable instead of Internal for per-RPC creds errors (#1776) 2018-01-03 09:47:07 -08:00
encoding Add proper support for 'identity' encoding type (#1664) 2017-11-17 09:24:54 -08:00
examples examples: fix concurrent map accesses in route_guide server (#1752) 2017-12-18 10:21:30 -08:00
grpclb Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08:00
grpclog Fix missing and wrong license (#1422) 2017-08-04 13:46:18 -07:00
health *: replace deprecated grpc.Errorf calls with status.Errorf (#1651) 2017-11-06 10:24:20 -08:00
internal status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
interop status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
keepalive autofix license notice 2017-06-08 14:42:19 +02:00
metadata stats: add methods to allow setting grpc-trace-bin and grpc-tags-bin headers (#1404) 2017-08-24 10:00:40 -07:00
naming naming: Fix build constraints for go1.6 and go1.7 (#1718) 2017-12-07 12:43:58 -08:00
peer autofix license notice 2017-06-08 14:42:19 +02:00
reflection *: replace deprecated grpc.Errorf calls with status.Errorf (#1651) 2017-11-06 10:24:20 -08:00
resolver Add WithResolverUserOptions for custom resolver build options (#1711) 2017-12-06 15:54:01 -08:00
stats status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
status status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
stress *: replace deprecated grpc.Errorf calls with status.Errorf (#1651) 2017-11-06 10:24:20 -08:00
tap Update ServerInHandle comments (#1437) 2017-08-14 10:05:02 -07:00
test server: fix bug preventing Serve from exiting when Listener is closed (#1765) 2017-12-22 12:42:04 -08:00
testdata Add testdata package and unify testdata to only one dir (#1297) 2017-07-25 10:24:45 -07:00
transport credentials: return Unavailable instead of Internal for per-RPC creds errors (#1776) 2018-01-03 09:47:07 -08:00
.please-update balancer_test: possible ctx leak, cancel before break (#1479) 2017-08-28 08:51:54 -07:00
.travis.yml travis: fix GOARCH=386 and add misspell check (#1658) 2017-11-08 13:40:05 -08:00
AUTHORS add AUTHORS and LICENSE 2017-06-08 14:37:28 +02:00
CONTRIBUTING.md Update CONTRIBUTING.md to CNCF CLA 2017-12-11 09:04:48 -08:00
LICENSE Make Apache 2.0 LICENSE file a verbatim copy (#1329) 2017-06-21 10:20:47 -07:00
Makefile reduce timeout for tests to 5m (7m for testrace) (#1635) 2017-10-31 14:07:09 -07:00
README.md Re-add support for Go1.6 (#1603) 2017-10-20 12:05:20 -07:00
backoff.go Remove single-entry var blocks (#1589) 2017-10-18 09:59:23 -07:00
backoff_test.go add license for some files (#1296) 2017-06-12 18:10:06 -07:00
balancer.go grpc: fix deprecation comments to conform to standard (#1691) 2017-12-18 09:23:42 -08:00
balancer_conn_wrappers.go Notify parent ClientConn to re-resolve in grpclb (#1699) 2017-12-18 15:36:55 -08:00
balancer_switching_test.go Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08:00
balancer_test.go status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
balancer_v1_wrapper.go grpc: fix deprecation comments to conform to standard (#1691) 2017-12-18 09:23:42 -08:00
call.go Avoid copying headers/trailers in unary RPCs unless requested by CallOptions (#1775) 2018-01-03 09:13:06 -08:00
call_test.go status: add Code convenience function (#1754) 2017-12-18 15:00:50 -08:00
clientconn.go Don't set reconnect parameters when the server has already responded. (#1779) 2018-01-04 11:16:47 -08:00
clientconn_test.go Fix flakey test. (#1771) 2017-12-28 09:31:16 -08:00
codec.go protoCodec: avoid buffer allocations if proto.Marshaler/Unmarshaler (#1689) 2017-12-01 15:32:05 -08:00
codec_benchmark_test.go codec_benchmark_test: fix racy unmarshal behavior and make some cleanups (#1642) 2017-11-02 13:42:21 -07:00
codec_test.go autofix license notice 2017-06-08 14:42:19 +02:00
codegen.sh FIX: use /usr/bin/env bash in shebang 2016-12-17 20:45:30 +01:00
doc.go Fix missing and wrong license (#1422) 2017-08-04 13:46:18 -07:00
go16.go Re-add support for Go1.6 (#1603) 2017-10-20 12:05:20 -07:00
go17.go Re-add support for Go1.6 (#1603) 2017-10-20 12:05:20 -07:00
grpclb.go grpclb: Remove duplicate init() (#1764) 2017-12-22 13:43:22 -08:00
grpclb_picker.go New grpclb implementation (#1558) 2017-11-27 11:16:26 -08:00
grpclb_remote_balancer.go Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08:00
grpclb_util.go Notify parent ClientConn to re-resolve in grpclb (#1699) 2017-12-18 15:36:55 -08:00
interceptor.go autofix license notice 2017-06-08 14:42:19 +02:00
picker_wrapper.go New grpclb implementation (#1558) 2017-11-27 11:16:26 -08:00
picker_wrapper_test.go fix misspell (#1592) 2017-10-19 09:34:07 -07:00
pickfirst.go Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08:00
pickfirst_test.go Add dial option to set balancer (#1697) 2017-12-18 15:35:42 -08:00
proxy.go Re-add support for Go1.6 (#1603) 2017-10-20 12:05:20 -07:00
proxy_test.go Skip proxy_test in race mode (#1584) 2017-10-17 11:26:58 -07:00
resolver_conn_wrapper.go Add WithResolverUserOptions for custom resolver build options (#1711) 2017-12-06 15:54:01 -08:00
resolver_conn_wrapper_test.go Fix parseTarget for unix socket address without scheme (#1611) 2017-10-23 16:34:03 -07:00
resolver_test.go Add WithResolverUserOptions for custom resolver build options (#1711) 2017-12-06 15:54:01 -08:00
rpc_util.go Avoid copying headers/trailers in unary RPCs unless requested by CallOptions (#1775) 2018-01-03 09:13:06 -08:00
rpc_util_test.go Remove buf copy when the compressor exist (#1427) 2017-08-25 12:26:38 -07:00
server.go server: fix bug preventing Serve from exiting when Listener is closed (#1765) 2017-12-22 12:42:04 -08:00
server_test.go grpc: fix deprecation comments to conform to standard (#1691) 2017-12-18 09:23:42 -08:00
service_config.go Change parseTimeout to not handle non-second durations (#1706) 2017-12-05 10:04:04 -08:00
service_config_test.go Change parseTimeout to not handle non-second durations (#1706) 2017-12-05 10:04:04 -08:00
stream.go Avoid copying headers/trailers in unary RPCs unless requested by CallOptions (#1775) 2018-01-03 09:13:06 -08:00
trace.go Truncate payload trace string, and turn trace off by default (#1509) 2017-09-08 11:13:41 -07:00
vet.sh vet: run golint on _string files (#1749) 2017-12-18 10:58:57 -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

This requires Go 1.6 or later. Go 1.7 will be required as of the next gRPC-Go release (1.8).

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