The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
Go to file
Jan Tattermusch 9f87a1dbb5
avoid collision with pre-installed protoc on grpc-win2016 workers (#29171)
2022-03-21 16:52:25 +01:00
.bazelci Remove ubuntu1604 from presubmit.yml (#26587) 2021-07-15 09:22:45 -07:00
.github Use separate issue queues for each wrapped language (#29150) 2022-03-18 13:59:28 -07:00
bazel Remove deprecated use_cfstream arg from gRPC build system (#29140) 2022-03-17 12:28:27 -07:00
cmake activate ccache for selected win builds (#28735) 2022-03-10 19:50:34 +01:00
doc resolver: refactor common code for polling-based resolvers (#28979) 2022-03-10 10:45:52 -08:00
etc Update root pem certs (#27539) 2021-10-01 04:46:12 -07:00
examples Small cleanup (#29125) 2022-03-16 18:26:41 -07:00
include We must always post a recv initial metadata (#29145) 2022-03-17 17:28:14 -07:00
spm-core-include Support swift package manager for grpc-core and grpc-cpp. 2020-10-28 14:53:37 -07:00
spm-cpp-include Support swift package manager for grpc-core and grpc-cpp. 2020-10-28 14:53:37 -07:00
src make sure to always receive initial metadata in ruby (#29155) 2022-03-18 20:30:37 -07:00
summerofcode Update .cc and .md files 2019-01-30 11:24:09 -05:00
templates Use a non-root user in Node interop docker images (#29062) 2022-03-15 14:41:21 -07:00
test Add special logging for infinite times (#29158) 2022-03-18 20:10:34 -07:00
third_party [Objc] add ios libuv timer test (#28570) 2022-03-16 13:03:01 -07:00
tools avoid collision with pre-installed protoc on grpc-win2016 workers (#29171) 2022-03-21 16:52:25 +01:00
.bazelignore update .bazelignore file for new xds proto repo (#27763) 2021-10-19 09:11:53 +02:00
.bazelrc Add suggested alias for bazelrc import location 2018-10-24 23:31:54 +02:00
.clang-format Adjust include order per style guide (#27175) 2021-09-08 12:14:44 -07:00
.clang-tidy Upgrade clang to 13 for clang-format, clang-tidy, and sanity (#28763) 2022-02-02 11:03:26 -08:00
.editorconfig
.gitallowed .gitallowed modification on the path of test files. 2020-02-26 15:15:40 -08:00
.gitattributes TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
.gitignore Merge the 3 repeating Python binary compilations (Attempt 2) (#28543) 2022-01-14 09:25:33 -08:00
.gitmodules Correct the c-ares gitmodule branch name (#28780) 2022-02-03 11:36:55 -08:00
.istanbul.yml
.pylintrc Introduce Python import sorting to our sanity test suite (#26768) 2021-07-26 12:31:21 -07:00
.pylintrc-examples Introduce Python import sorting to our sanity test suite (#26768) 2021-07-26 12:31:21 -07:00
.pylintrc-tests Introduce Python import sorting to our sanity test suite (#26768) 2021-07-26 12:31:21 -07:00
.rspec
.travis.yml Remove gflags. 2020-11-14 03:03:55 +01:00
.yapfignore More pythons to be formatted 2020-01-03 22:21:23 -08:00
.yardopts
AUTHORS [Aio] Unary unary client call barebones implementation 2019-09-11 20:37:45 +02:00
BUILD TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
BUILDING.md Fix typo BUILDING.md (#27331) 2021-09-13 10:13:49 -07:00
CMakeLists.txt TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
CODE-OF-CONDUCT.md Fix code of conduct 2017-06-08 13:15:06 -07:00
CONCEPTS.md Tiny update to protocol overview doc. (#26396) 2021-09-07 14:07:56 -07:00
CONTRIBUTING.md Update note on closed feature requests with help wanted label 2020-05-05 01:13:27 -07:00
GOVERNANCE.md Add GOVERNANCE.md 2019-09-20 11:38:05 -07:00
Gemfile
LICENSE BSD 3-Clause license lint fix (#27499) 2021-09-29 13:33:39 -07:00
MAINTAINERS.md I am back (#26464) 2021-06-11 15:12:02 -07:00
MANIFEST.md Abstract libuv implementation 2018-03-13 01:21:42 -07:00
Makefile TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
NOTICE.txt
OWNERS Update a few owners files (#26854) 2021-08-02 21:50:38 -07:00
PYTHON-MANIFEST.in Add Python xDS user agent (#26191) 2021-06-14 16:35:00 -07:00
Package.swift gRPC Package.swift patch (#28355) 2022-02-03 16:17:35 -08:00
README.md Add grpc-swift to language list (#28743) 2022-02-08 10:00:12 -08:00
Rakefile Enable ccache in more builds (#28665) 2022-01-25 20:37:04 +01:00
SECURITY.md Add security policy doc 2021-01-22 10:38:04 -08:00
TROUBLESHOOTING.md Typo 2020-10-04 19:42:06 -04:00
WORKSPACE Make Compatible with Bazel 5.0 (#28683) 2022-02-11 15:18:18 -08:00
_metadata.py Bump version to 1.46.0-dev (on master branch) (#29064) 2022-03-09 16:44:12 -08:00
build_autogenerated.yaml TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
build_config.rb Bump core version to 23.0.0 for upcoming release (#29026) 2022-03-04 12:47:45 -08:00
build_handwritten.yaml Bump version to 1.46.0-dev (on master branch) (#29064) 2022-03-09 16:44:12 -08:00
composer.json update required minimal php version to 7.0 2020-11-19 23:52:44 +03:00
config.m4 Expose channel stack type to builder (#29088) 2022-03-15 21:33:32 -07:00
config.w32 Expose channel stack type to builder (#29088) 2022-03-15 21:33:32 -07:00
gRPC-C++.podspec TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
gRPC-Core.podspec TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
gRPC-ProtoRPC.podspec Bump version to 1.46.0-dev (on master branch) (#29064) 2022-03-09 16:44:12 -08:00
gRPC-RxLibrary.podspec Bump version to 1.46.0-dev (on master branch) (#29064) 2022-03-09 16:44:12 -08:00
gRPC.podspec Bump version to 1.46.0-dev (on master branch) (#29064) 2022-03-09 16:44:12 -08:00
grpc.bzl Make Buildifier Sanity Test Strict (#27807) 2021-11-03 14:57:04 -07:00
grpc.def Eliminate gRPC insecure build (#25586) 2022-02-10 11:17:18 -08:00
grpc.gemspec TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
grpc.gyp TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
package.xml TlsCredentials: Comparator implementation (#28940) 2022-03-16 17:11:07 -07:00
requirements.bazel.txt Create Bazel gevent test harness (#27507) 2021-10-07 14:04:34 -07:00
requirements.txt Remove enum34 from requirements.txt 2020-09-29 15:17:38 -07:00
setup.cfg Polish and add AsyncIO examples 2020-12-08 13:44:43 -08:00
setup.py Remove GRPC_ENABLE_FORK_SUPPORT from setup.py (#29103) 2022-03-15 14:38:23 -07:00

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. gRPC enables client and server applications to communicate transparently, and simplifies the building of 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 method for adding dependencies to a user's chosen language (if there is one). In most languages, the gRPC runtime comes as a package available in a user's language package manager.

For instructions on how to use the language-specific gRPC runtime for a 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
  • Kotlin: 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

Per-language quickstart guides and tutorials can be found in the documentation section on the grpc.io website. 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 changes to the gRPC codebase. The "How to contribute" document also contains info on how the contribution 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 the Performance dashboard for performance numbers of master branch daily builds.

Concepts

See gRPC Concepts

About This Repository

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

Libraries in different languages may be in various 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# (core library based) src/csharp
Objective-C src/objective-c
Language Source repo
Java grpc-java
Kotlin grpc-kotlin
Go grpc-go
NodeJS grpc-node
WebJS grpc-web
Dart grpc-dart
.NET (pure C# impl.) grpc-dotnet
Swift grpc-swift