0.01
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Instrument your web app to export Prometheus metrics.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

= 3.6.0
= 0.11.3
= 5.1.4
= 12.3.0
= 3.7.0

Runtime

 Project Readme

GDS metrics for Ruby apps

GDS Metrics are in Alpha and these instructions are subject to change.

GDS Ruby metrics enable your Ruby web app to export performance data to Prometheus, you can add metrics to your app using this Ruby gem.

This gem is a thin wrapper around gitlab's prometheus-client-mmap that:

  • adds a railtie for easy configuration for Rails apps
  • fixes label naming so it's consistent with the official Prometheus Ruby Client
  • changes url path labels from unique paths to their Rails controller and action if the url path matches a route. For example - blogs/8, blogs/9 => blogs#view
  • protects your /metrics endpoint with basic HTTP authentication for apps deployed to GOV.UK PaaS

Once you’ve added the gem, metrics data is served from your app's metrics endpoint and is scraped by Prometheus. This data can be turned into performance dashboards using Grafana.

You can read more about the Reliability Engineering monitoring solution here.

Before using GDS metrics

Before using GDS metrics you should have:

How to install metrics for Rails apps

To use GDS metrics you must:

  1. Add the latest version of the gem to your Gemfile, for example:

    gem 'gds_metrics'

  2. Run the following command to install the gem:

    bundle install

  3. Restart your Rails server by running:

    bundle exec rails server

  4. Visit any page of your app (for example the index page) to generate some site traffic

  5. Visit the metrics endpoint at /metrics to check if the gem was set up correctly. If it's set up correctly, you will see a page containing some metrics (for example http_req_duration_seconds).

If you're not using Rails, you'll also need to add GDS::Metrics::Middleware as Rack middleware before running your Rails server. You’ll also need to refer to your framework's documentation, for example Sinatra or Grape middleware.

Running on GOV.UK Platform as a Service (PaaS)

When running on PaaS, citizens won’t see your metrics in production as this endpoint is automatically protected with authentication.

The PaaS documentation has information on how you can deploy a basic Ruby on Rails app. You can also read the official Cloud Foundry guide which has detailed information on deploying Ruby on Rails apps.

Testing

The test suite can be run in full using bundle exec rake, this includes unit and integration tests as well as a code style check using the Govuk Linter.

Individual unit tests in /spec/gds_metrics can be run using rspec path/to/test.rb

Because of the need to test the apps integration with rails there is a dummy Rails app within /spec. This app is run from within the test suite and integration tests are then executed against it. At the moment these tests cannot be run individually but can be run separately from the unit tests by running pushd spec/dummy && bundle exec rake && popd

Optional configuration

You can change the path for serving metrics (by default /metrics) by setting the PROMETHEUS_METRICS_PATH environment variable.

If you are running blue-green deployments through a cf plugin like autopilot you should disable the basic auth on the \metrics endpoint and use IP whitelisting by setting the METRICS_BASIC_AUTH environment variable to false. This will minimise gaps in metrics during deployment.

How to setup extended metrics

While common metrics are recorded by default, you can also:

  • record your own metrics such as how many users are signed up for your service, or how many emails it's sent
  • use the Prometheus interface to set your own metrics as the metrics Ruby gem is built on top of prometheus-client-mmap

You can read more about the different types of metrics available in the Prometheus documentation.

Contributing

GDS Reliability Engineering welcome contributions. We'd appreciate it if you write tests with your changes and document them where appropriate, this will help us review them quickly.

Licence

This project is licensed under the MIT License.