A tool for cURLing gRPC services.
There aren't many tools out there that make debugging gRPC easy. One of the approaches is to create a client stub for your language of choice. However, this requires a compilation step that adds a lot of overhead to your workflow.
When debugging a REST API, the instinct is often to use cURL. gURL is meant to facilitate a similar workflow for debugging gRPC services, since it only requires a path to where your protos are located. No compilation or stub generation required! Just configure gURL to point to your protos, start your server, form your request as a JSON string (as you would for cURL), and go.
gURL is built in Go 1.10.
gURL uses dep for dependencies. However, vendored deps are not checked in because of the presence of the Gopkg.lock. To build locally:
# Install dep, or use brew install dep on OS X
curl https://raw.githubusercontent.com/golang/dep/master/install.sh | sh
# Pulls all dependencies
make deps
# Create a cross platform build
make build
This will generate cross platform binaries in the release/
folder. You'll need to give yourself executable permissions for the relevant binary and then move it somewhere in your $PATH.
Example:
chmod +x gurl-darwin-amd64
mv gurl-darwin-amd64 /usr/local/bin/gurl
You can also download a copy of gURL on the platform of your choice from gURL's releases page.
Configure gURL with the absolute path to your protos, so it can load them.
gurl config
gURL will prompt for your import paths and service paths (the nomenclature for these paths is poor and prone to change.) Both are just a comma delimited list of absolute paths to your proto files. The distinction is that your import paths are external protos that you're importing, and your service paths are your protos.
Here is an example of a gURL config (found at $HOME/.gurl/config):
local:
importpaths:
- ""
servicepaths:
- /Users/johnsmith/go/src/github.com/johnsmith/myprotos
kubeconfig: /Users/johnsmith/.kube/config
gURL's request format is as follows:
gurl -u <protocol|optional>://<k8-context|optional>/<host|kubernetes-service-name>:<port>/<service>/<rpc> -d '{ "field_name": "field_value" }'
gURL also supports forwarding requests to a Kubernetes server, so long as your kubeconfig is located in the default director of $HOME/.kube/config. If you format your request with the protocol k8://, gURL will know to send the Kubernetes request to a Kubernetes service via port-forwarding.
Valid URL formats:
# URL with protocol
http://localhost:50051/helloworld/Greeter -d '{ "name": "cat cai" }'
# URL without protocol
localhost:50051/helloworld/Greeter -d '{ "name": "cat cai" }'
# URL with K8 protocol - in this case, my-service should be your Kubernetes service name, along with the service port used to expose your gRPC service
k8://my-k8-context/my-service:50051/helloworld/Greeter -d '{ "name": "cat cai" }'
You should format JSON according to the protobuf docs laid out here.
Caveats:
- This only supports unary calls
Places to improve:
- Configurable log levels
- gURL configurations that are local to a project
- Pass in proto files as an arg instead of as a configuration
There's a lot of potential work to be done for gURL and we welcome contributions.
If you're interested in contributing, first look through gURL's issues and pull requests for anything that might be similar (there's no reason to unnecessarily duplicate work).
If you don't see anything listed, feel free to open an issue or pull request to open up a discussion.
Huge props to jhump for his protoreflect package, which gURL makes heavy use of.