Podinfo is a tiny web application made with Go that showcases best practices of running microservices in Kubernetes.
Specifications:
- Release automation (Make/TravisCI/CircleCI/Quay.io/Google Cloud Container Builder/Skaffold/Weave Flux)
- Multi-platform Docker image (amd64/arm/arm64/ppc64le/s390x)
- Health checks (readiness and liveness)
- Graceful shutdown on interrupt signals
- Prometheus instrumentation (RED metrics)
- Dependency management with golang/dep
- Structured logging with zerolog
- Error handling with pkg/errors
- Helm chart
Web API:
GET /
prints runtime information, environment variables, labels and annotationsGET /version
prints podinfo version and git commit hashGET /metrics
http requests duration and Go runtime metricsGET /healthz
used by Kubernetes liveness probeGET /readyz
used by Kubernetes readiness probePOST /readyz/enable
signals the Kubernetes LB that this instance is ready to receive trafficPOST /readyz/disable
signals the Kubernetes LB to stop sending requests to this instanceGET /error
returns code 500 and logs the errorGET /panic
crashes the process with exit code 255POST /echo
echos the posted content, logs the SHA1 hash of the contentGET /echoheaders
prints the request HTTP headersPOST /job
long running job, json body:{"wait":2}
POST /write
writes the posted content to disk at /data/hash and returns the SHA1 hash of the contentPOST /read
receives a SHA1 hash and returns the content of the file /data/hash if existsPOST /backend
forwards the call to the backend service onhttp://backend-podinfo:9898/echo