Skip to content

A command-line tool (and Lambda) for collecting Buildkite build/job metrics

License

Notifications You must be signed in to change notification settings

rbvigilante/buildkite-metrics

 
 

Repository files navigation

Buildkite Metrics

A command-line tool for collecting Buildkite build/job statistics for external metrics systems. Currently AWS Cloudwatch and StatsD are supported.

Build status

Installing

Either download the latest binary from buildkite-metrics/buildkite-metrics-Linux-x86_64 or install with:

go get github.com/buildkite/buildkite-metrics

Backends

By default metrics will be submitted to CloudWatch but the backend can be switched to StatsD using the command-line argument -backend statsd. The StatsD backend supports the following arguments

  • -statsd-host HOST: The StatsD host and port (defaults to 127.0.0.1:8125).
  • -statsd-tags: Some StatsD servers like the agent provided by DataDog support tags. If specified, metrics will be tagged by queue and pipeline otherwise metrics will include the queue/pipeline name in the metric. Only enable this option if you know your StatsD server supports tags.

Development

You can build and run the binary tool locally with golang installed:

go run *.go -org [myorg] -token [buildkite api access token]

Currently this will publish metrics to Cloudwatch under the custom metric prefic of Buildkite, using AWS credentials from your environment. The machine will require the cloudwatch:PutMetricData IAM permission, and the Buildkite API Access token requires the scopes read_pipelines, read_builds and read_agents.

Metrics

The following metrics are gathered:

Buildkite > RunningBuildsCount
Buildkite > RunningJobsCount
Buildkite > ScheduledBuildsCount
Buildkite > ScheduledJobsCount
Buildkite > UnfinishedJobsCount
Buildkite > IdleAgentsCount
Buildkite > BusyAgentsCount
Buildkite > TotalAgentsCount

Buildkite > (Queue) > RunningBuildsCount
Buildkite > (Queue) > RunningJobsCount
Buildkite > (Queue) > ScheduledBuildsCount
Buildkite > (Queue) > ScheduledJobsCount
Buildkite > (Queue) > UnfinishedJobsCount
Buildkite > (Queue) > IdleAgentsCount
Buildkite > (Queue) > BusyAgentsCount
Buildkite > (Queue) > TotalAgentsCount

Buildkite > (Pipeline) > RunningBuildsCount
Buildkite > (Pipeline) > RunningJobsCount
Buildkite > (Pipeline) > ScheduledBuildsCount
Buildkite > (Pipeline) > ScheduledJobsCount
Buildkite > (Pipeline) > UnfinishedJobsCount

AWS Lambda

An AWS Lambda bundle is created and published as part of the build process.

It's entrypoint is handler.handle, it requires a python2.7 environment and makes use of the following env vars:

  • BUILDKITE_ORG
  • BUILDKITE_TOKEN
  • BUILDKITE_BACKEND
  • BUILDKITE_QUEUE
  • BUILDKITE_QUIET

Checkout https://github.com/buildkite/elastic-ci-stack-for-aws/blob/master/templates/metrics.yml for examples of usage.

License

See LICENSE.md (MIT)

About

A command-line tool (and Lambda) for collecting Buildkite build/job metrics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 90.9%
  • Shell 6.7%
  • Makefile 2.4%