Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bradleyjkemp/grpc-tools
A suite of gRPC debugging tools. Like Fiddler/Charles but for gRPC.
https://github.com/bradleyjkemp/grpc-tools
debugging-tool grpc interceptor middleware proxy tls
Last synced: about 19 hours ago
JSON representation
A suite of gRPC debugging tools. Like Fiddler/Charles but for gRPC.
- Host: GitHub
- URL: https://github.com/bradleyjkemp/grpc-tools
- Owner: bradleyjkemp
- License: mit
- Created: 2019-04-14T15:56:05.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-11-14T10:42:44.000Z (about 1 year ago)
- Last Synced: 2025-01-11T09:06:26.895Z (8 days ago)
- Topics: debugging-tool, grpc, interceptor, middleware, proxy, tls
- Language: Go
- Homepage:
- Size: 234 KB
- Stars: 1,220
- Watchers: 21
- Forks: 78
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-fancy-toolkit - Grpc调试工具, grpc-tools
- awesome-grpc - grpc-tools - A suite of gRPC debugging tools. Like Fiddler/Charles but for gRPC. (Tools / Testing)
- awesome-systools - grpc-tools
README
# grpc-tools [![CircleCI](https://circleci.com/gh/bradleyjkemp/grpc-tools/tree/master.svg?style=svg)](https://circleci.com/gh/bradleyjkemp/grpc-tools/tree/master) [![GitHub release](https://img.shields.io/github/release/bradleyjkemp/grpc-tools.svg)](https://github.com/bradleyjkemp/grpc-tools/releases/latest)
A suite of tools for gRPC debugging and development. Like [Fiddler](https://www.telerik.com/fiddler)/[Charles](https://www.charlesproxy.com/) but for gRPC!
The main tool is `grpc-dump` which transparently intercepts network traffic and logs all gRPC and gRPC-Web requests with full metadata as a JSON [stream](grpc-dump/README.md#JSON-stream-output). This stream is easily readable as it is or you can use tools like [`jq`](https://stedolan.github.io/jq/) for more complex visualisation.
![demo](demo.svg "Simple grpc-dump demo")
This repository currently includes:
* [`grpc-dump`](#grpc-dump): a small gRPC proxy that dumps RPC details to a file for debugging, and later analysis/replay.
* [`grpc-replay`](grpc-replay): takes the output from `grpc-dump` and replays requests to the server.
* [`grpc-fixture`](#grpc-fixture): a proxy that takes the output from `grpc-dump` and replays saved responses to client requests.
* [`grpc-proxy`](grpc-proxy): a library for writing gRPC intercepting proxies. `grpc-dump` and `grpc-fixture` are both built on top of this library.These tools are in alpha so expect breaking changes between releases. See the [changelog](CHANGELOG.md) for full details.
### Installation:
The recommended way to install these tools is via [Homebrew](https://brew.sh/) using:
```bash
brew install bradleyjkemp/formulae/grpc-tools
```Alternatively, binaries can be downloaded from the GitHub [releases page](https://github.com/bradleyjkemp/grpc-tools/releases/latest).
Or you can build the tools from source using:
```bash
go install github.com/bradleyjkemp/grpc-tools/...
```## grpc-dump
`grpc-dump` lets you see all of the gRPC requests being made by applications on your machine without any code changes required to applications or servers.
Simply start `grpc-dump` and configure your system/application to use it as a HTTP(S) proxy. You'll soon see requests logged in full as a JSON stream with service and method names.
Even if you don't have the original `.proto` files, `grpc-dump` will attempt to deserialise messages heuristically to give a human readable form.
```bash
# start the proxy (leave out the --port flag to automatically pick on)
grpc-dump --port=12345# in another terminal, run your application pointing it at the proxy
# Warning: if your application connects to a localhost/127.0.0.1 address then proxy settings
# are usually ignored. To fix this you can use a service like https://readme.localtest.me
http_proxy=http://localhost:12345 my-app# all the requests made by the application will be logged to standard output in the grpc-dump window e.g.
# {"service": "echo", "method": "Hi", "messages": ["....."] }
# JSON will be logged to STDOUT and any info or warning messages will be logged to STDERR
```Many applications expect to talk to a gRPC server over TLS. For this you need to use the `--key` and `--cert` flags to point `grpc-dump` to certificates valid for the domains your application connects to.
The recommended way to generate these files is via the excellent [`mkcert`](https://github.com/FiloSottile/mkcert) tool. `grpc-dump` will automatically use any `mkcert` generated certificates in the current directory.
```bash
# Configure your system to trust mkcert certificates
mkcert -install# Generate certificates for domains you want to intercept connections to
mkcert mydomain.com *.mydomain.com# Start grpc-dump using the key and certificate created by mkcert
# Or start grpc-dump from the same directory and it will
# detect them automatically
grpc-dump --key=mydomain.com-key.pem --cert=mydomain.com.pem
```More details for using `grpc-dump` (including the specification for the JSON output) can be found [here](grpc-dump/README.md).
## grpc-fixture
```bash
# save the (stdout) output of grpc-dump to a file
grpc-dump --port=12345 > my-app.dump# in another, run your application pointing it at the proxy
http_proxy=http://localhost:12345 my-app# now run grpc-fixture from the previously saved output
grpc-fixture --port=12345 --dump=my-app.dump# when running the application again, all requests will
# be intercepted and answered with saved responses,
# no requests will be made to the real gRPC server.
http_proxy=http://localhost:12345 my-app
```For applications that expect a TLS server, the same `--key` and `--cert` flags can be used as described above for `grpc-dump`.
More details for using `grpc-fixture` can be found [here](grpc-fixture/README.md).