The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
C++ Python C# C Makefile Ruby Other
Switch branches/tags
Clone or download
ncteisen Merge pull request #15894 from cartr/respect_iov_max
tcp_posix.cc: adhere to IOV_MAX in tcp_flush
Latest commit a93fdfc Jul 17, 2018
Permalink
Failed to load latest commit information.
.github Update ISSUE_TEMPLATE.md Apr 27, 2018
.vscode Adding shim for debugging node tests using vscode. Feb 21, 2017
bazel Merge pull request #15070 from Vizerai/filter_port Jun 19, 2018
cmake cmake changes Jun 5, 2018
doc Update keepalive.md Jul 14, 2018
etc update SSL root certificate from Mozilla Apr 17, 2018
examples overhaul of top-level .md files Jun 20, 2018
include Add server load reporting service Jul 14, 2018
src Merge pull request #15894 from cartr/respect_iov_max Jul 17, 2018
summerofcode Revert "Verify early OK behavior" Mar 20, 2018
templates Kokoro setup for building gRPC Python with Bazel Jul 13, 2018
test Merge pull request #16024 from apolcyn/gcd_interop Jul 16, 2018
third_party Step 3 of multipool RBE configuration. Jul 13, 2018
tools Set runs_per_test=2 for tsan and add tsan bazel build to PR. Jul 16, 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 Add server load reporting service Jul 14, 2018
BUILDING.md bazel installation instructions Jun 21, 2018
CMakeLists.txt Fix the muddled linkeage of channelz Jul 6, 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 Fix the muddled linkeage of channelz Jul 6, 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 Mention troubleshooting guide in top level README.md Jul 6, 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 Add python bazel deps needed to run resolver component tests Feb 14, 2018
build.yaml Fix the muddled linkeage of channelz Jul 6, 2018
build_config.rb Removing grpc_alarm from core requires a major version bump for core Jan 22, 2018
composer.json Use https://grpc.io consistently as the canonical URL Jul 10, 2017
config.m4 Fix the muddled linkeage of channelz Jul 6, 2018
config.w32 Fix the muddled linkeage of channelz Jul 6, 2018
gRPC-C++.podspec Fix the muddled linkeage of channelz Jul 6, 2018
gRPC-Core.podspec Fix the muddled linkeage of channelz Jul 6, 2018
gRPC-ProtoRPC.podspec Regenrate projects Jun 9, 2018
gRPC-RxLibrary.podspec Regenrate projects Jun 9, 2018
gRPC.podspec Regenrate projects Jun 9, 2018
grpc.bzl fix remaining license notices Jun 8, 2017
grpc.def Merge pull request #15909 from yihuazhang/local_channel_credentials Jul 6, 2018
grpc.gemspec Fix the muddled linkeage of channelz Jul 6, 2018
grpc.gyp Fix the muddled linkeage of channelz Jul 6, 2018
package.xml Fix the muddled linkeage of channelz Jul 6, 2018
requirements.txt Pin cython to 0.28.3 temporarily Jul 9, 2018
setup.cfg Enable running Python formatting Jan 17, 2017
setup.py Merge branch 'master' of github.com:grpc/grpc into nanopb_build_cleanup Jun 4, 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.

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