You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Benjamin 2128d51671
not needed anymore
3 years ago
grafana initial commit 4 years ago
prometheus mux name change in dockerfile/prometheus.yml, seperate goroutine for ticker 4 years ago
util initial commit 4 years ago
.gitignore moar names 3 years ago
.travis.yml Added travis-ci build 4 years ago
Dockerfile change binary names 3 years ago
LICENSE Initial commit 4 years ago remove custom prometheus registry, update docs 3 years ago
docker-compose.yml change binary names 3 years ago
gauge.go change name from sample to simple 3 years ago
handlers.go add logger, add prometheus wrapper 4 years ago
handlers_test.go add unit test for the http handler on / 3 years ago
main.go change name from sample to simple 3 years ago

Sample Project for a gorilla/mux based go rest API with prometheus metrics enabled and simple request logging.

Build Status

the main app is a sample golang application with a gorilla/mux based router.

port 8080 is used and you can build it yourself with: go get -d

linux: CGO_ENABLED=0 GOOS=linux go build -o mux

OSX: CGO_ENABLED=0 GOOS=darwin go build -o mux

after this you should be able to start it with: ./mux

and test it with curl localhost:8080

or for the metrics endpoint: curl localhost:8080/metrics

If you do not want to build it yourself just use docker or even more convenient docker-compose

docker-compose up

this will launch a stack with grafana, prometheus and the mux application

You can reach your applications under:


  • localhost:3000/login
  • admin:password


  • localhost:9090


  • localhost:8080

If you want to check if prometheus scrapes the mux application correctly, you can use the util/ script to configure the prometheus datasource. After this you only have to import the dashboards in the grafana folder. The mux-dashboard.json is a very basic dashboard which displays the go_threads of both prometheus and mux.

i added a simple prometheus gauge in the gauge.go file to show how to get updated metrics while the http server is running and blocking.


All patches are welcome! If you find something is missing or broken send me a PR or file an issue.