Opinionated microservice kit to help developers to build microservices with go.
A pace/bricks microservice is:
- built as a docker container
- deployed into a kubernetes cluster
- configured using environment variables (TWELVE-FACTOR APP)
- monitored using prometheus
- reports errors to sentry
- samples traces to jaeger
- logs to stdout using json
- offers health endpoints
- connects to backend services with logging, metrics and tracing:
- postgres (logging, metrics, tracing)
- redis (logging, metrics, tracing)
- http (logging, metrics, tracing, retries)
- provides two commands control and daemon
- provides a RESTful API
- code is generated from the OpenAPIv3 spec
- authenticated via OAuth2
- encoded using json:api
- that supports logging, tracing and metrics
go get github.com/pace/bricks/cmd/pb
pb -h
Read our contributors guide.
- A working go installation
- A working git installation
- Use
make test
to test without dependencies - Use
docker-compose run testserver make integration
to test with dependencies - Use
make testserver
to start a testserver that will be started with dependencies. In order to update the server one need todocker-compose restart testserver
Variable | Description |
---|---|
PACE_BRICKS_EDITOR |
The path to the editor that should be used for opening a project. Defaults to $EDITOR . |
PACE_BRICKS_PATH |
The path where new project should be created. Defaults to $HOME/PACE . |