The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
C++ Python C# C Makefile Ruby Other
Switch branches/tags
Clone or download
Latest commit a165183 Aug 14, 2018
Permalink
Failed to load latest commit information.
.github regenerate CODEOWNERS Aug 10, 2018
.vscode Adding shim for debugging node tests using vscode. Feb 21, 2017
bazel upgrade protobuf in grpc_deps.bzl to v3.6.1 Aug 7, 2018
cmake remove matt-kwong from OWNERS Aug 10, 2018
doc Merge pull request #16261 from muxi/dynamic-cfstream-init Aug 13, 2018
etc update roots.pem Aug 8, 2018
examples Merge pull request #16252 from mehrdada/python_reflection_docs Aug 6, 2018
include Merge branch 'master' into rq-threads-2 Aug 13, 2018
src Merge pull request #16319 from sreecha/transport-comments Aug 13, 2018
summerofcode Add GSoC report (Naresh) Aug 14, 2018
templates pkgconfig: add gpr to grpc's Requires.private Aug 13, 2018
test Merge branch 'master' into rq-threads-2 Aug 13, 2018
third_party upgrade third_party/protobuf to v3.6.1 Aug 7, 2018
tools Merge pull request #16261 from muxi/dynamic-cfstream-init Aug 13, 2018
.clang-format Support cleaning objc files Apr 12, 2018
.clang-tidy Enable the performance-* clang-tidy checks Jun 14, 2018
.clang_complete Enable clang-tidy as a sanity check, fix up all known failures Nov 10, 2017
.editorconfig Adding an editorconfig configuration file. Jan 31, 2015
.gitignore Initial gevent support Mar 28, 2018
.gitmodules Skeleton of libcxxabi's usage. Jun 13, 2018
.istanbul.yml Moved gRPC node package root to repo root, made it depend on grpc.gyp Oct 1, 2015
.pylintrc Change notes on suppressions Jun 8, 2018
.pylintrc-tests Change notes on suppressions Jun 8, 2018
.rspec Bundled C core with Ruby library Dec 18, 2015
.travis.yml Have Travis build the Sample app with frameworks too Jul 16, 2016
.yardopts Adding a .yardopts file at the root so rubydocs isn't getting lost. Feb 13, 2016
AUTHORS change LICENSE, add AUTHORS Jun 8, 2017
BUILD Merge pull request #16261 from muxi/dynamic-cfstream-init Aug 13, 2018
BUILDING.md bazel installation instructions Jun 21, 2018
CMakeLists.txt Added system roots feature to load roots from OS trust store Aug 9, 2018
CODE-OF-CONDUCT.md Fix code of conduct Jun 8, 2017
CONCEPTS.md address comments Jun 20, 2018
CONTRIBUTING.md fix nits in CONTRIBUTING.md Jun 21, 2018
Gemfile Bundled C core with Ruby library Dec 18, 2015
LICENSE fix license file Jun 19, 2017
MANIFEST.md Abstract libuv implementation Mar 13, 2018
Makefile pkgconfig: add gpr to grpc's Requires.private Aug 13, 2018
NOTICE.txt change LICENSE, add AUTHORS Jun 8, 2017
OWNERS Substitute a11r for ctiller in all OWNERS files Jan 10, 2018
PYTHON-MANIFEST.in Add address_sorting to PYTHON-MANIFEST Apr 9, 2018
README.md Add link to packages.grpc.io Jul 24, 2018
Rakefile Remove source code and the grpc_c.so file that was built as a local b… Mar 27, 2018
TROUBLESHOOTING.md Address review comments. Jul 9, 2018
WORKSPACE Workspace changes to build gRPC Python with Bazel Jul 27, 2018
build.yaml Merge pull request #16261 from muxi/dynamic-cfstream-init Aug 13, 2018
build_config.rb Removing grpc_alarm from core requires a major version bump for core Jan 22, 2018
composer.json PHP: upgrade interop test google/auth version Aug 2, 2018
config.m4 Added system roots feature to load roots from OS trust store Aug 9, 2018
config.w32 Added system roots feature to load roots from OS trust store Aug 9, 2018
gRPC-C++.podspec Added system roots feature to load roots from OS trust store Aug 9, 2018
gRPC-Core.podspec Merge pull request #16261 from muxi/dynamic-cfstream-init Aug 13, 2018
gRPC-ProtoRPC.podspec Regenerate projects Jul 19, 2018
gRPC-RxLibrary.podspec Regenerate projects Jul 19, 2018
gRPC.podspec Regenerate projects Jul 19, 2018
grpc.bzl fix remaining license notices Jun 8, 2017
grpc.def Merge branch 'master' into rq-threads-2 Aug 9, 2018
grpc.gemspec Added system roots feature to load roots from OS trust store Aug 9, 2018
grpc.gyp Added system roots feature to load roots from OS trust store Aug 9, 2018
package.xml Added system roots feature to load roots from OS trust store Aug 9, 2018
requirements.bazel.txt Workspace changes to build gRPC Python with Bazel Jul 27, 2018
requirements.txt Pin cython to 0.28.3 temporarily Jul 9, 2018
setup.cfg Enable running Python formatting Jan 17, 2017
setup.py Revert "adding python version environmental markers in the new style" Aug 8, 2018

README.md

gRPC - An RPC library and framework

gRPC is a modern, open source, high-performance remote procedure call (RPC) framework that can run anywhere. It enables client and server applications to communicate transparently, and makes it easier to build connected systems.

Homepage: grpc.io
Mailing List: grpc-io@googlegroups.com

Join the chat at https://gitter.im/grpc/grpc

To start using gRPC

To maximize usability, gRPC supports the standard way of adding dependencies in your language of choice (if there is one). In most languages, the gRPC runtime comes in form of a package available in your language's package manager.

For instructions on how to use the language-specific gRPC runtime in your project, please refer to these documents

  • C++: follow the instructions under the src/cpp directory
  • C#: NuGet package Grpc
  • Dart: pub package grpc
  • Go: go get google.golang.org/grpc
  • Java: Use JARs from Maven Central Repository
  • Node: npm install grpc
  • Objective-C: Add gRPC-ProtoRPC dependency to podspec
  • PHP: pecl install grpc
  • Python: pip install grpcio
  • Ruby: gem install grpc
  • WebJS: follow the grpc-web instructions

You can find per-language quickstart guides and tutorials in Documentation section on grpc.io website. The code examples are available in the examples directory.

Precompiled bleeding-edge package builds of gRPC master branch's HEAD are uploaded daily to packages.grpc.io.

To start developing gRPC

Contributions are welcome!

Please read How to contribute which will guide you through the entire workflow of how to build the source code, how to run the tests and how to contribute your changes to the gRPC codebase. The document also contains info on how the contributing process works and contains best practices for creating contributions.

Troubleshooting

Sometimes things go wrong. Please check out the Troubleshooting guide if you are experiencing issues with gRPC.

Performance

See Performance dashboard for the performance numbers for the latest released version.

Concepts

See gRPC Concepts

About This Repository

This repository contains source code for gRPC libraries for multiple languages written on top of shared C core library src/core.

Libraries in different languages may be in different states of development. We are seeking contributions for all of these libraries.

Language Source
Shared C [core library] src/core
C++ src/cpp
Ruby src/ruby
Python src/python
PHP src/php
C# src/csharp
Objective-C src/objective-c
Language Source repo
Java grpc-java
Go grpc-go
NodeJS grpc-node
WebJS grpc-web
Dart grpc-dart