/go-observability-elastic

Observability in Golang applications using elasticstack :bar_chart:

Primary LanguageGoMIT LicenseMIT

Go Observability Elastic

  • APM Server

    • Web requests
    • SQL queries
    • Outgoing HTTP requests
    • Panic tracking
    • Custom spans
  • Metricbeat

    • Golang Metrics
    • Docker Metrics
    • System Metrics
    • Redis Metrics
  • Heartbeat

    • Uptime Metrics

Step by step

  • Start Kibana, Elasticsearch, APM-Server, Postgres, Redis and Heartbeat
make up

go-info

  • Start app
make up-go-info
  • listen port 3001
  • depends_on: postgres
Endpoint HTTP Method Description
/info GET Info network
/health GET Healthcheck
/query/{name} GET Query in Postgres
/http-external GET HTTP request for app go-app
/debug/vars GET Metrics for golang metrics

go-app

  • Start app
make up-go-info
  • listen port 3000
  • depends_on: redis
Endpoint HTTP Method Description
/ping GET Pong response
/health GET Healthcheck
/query/{name} GET Query in MySQL
/cache/{key} GET Find in Redis
/http-external GET HTTP request for app go-info
/debug/vars GET Metrics for golang metrics
  • Start Metricbeat after starting others containers
make up-metric

Others commands

  • Build app go-info
make up-go-info-build
  • Build app go-app
make up-go-app-build
  • Send request
##make request n=100 p=3001 r=/query/test
make request NUM_REQUESTS PORT RESOURCE
  • Kill all containers
make down