0.0
No commit activity in last 3 years
No release in over 3 years
Wraps dogstatsd-ruby with helpful conventions
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 10.0
~> 3.2
~> 1.2

Runtime

 Project Readme

Seismograph

A helper library for writing metrics and events to (http://datadoghq.com)

Installation

Add this line to your application's Gemfile:

gem 'seismograph'

If not using bundler, be sure to require the gem:

require 'seismograph'

Usage

Configure your statsd server:

Seismograph.config do |config|
  config.app_name    = 'cabbagepult'  # optional
  config.env         = 'staging'      # optional, defaults to `RAILS_ENV` or `RACK_ENV`
  config.statsd_host = ENV.fetch('STATSD_HOST')
  config.statsd_port = ENV.fetch('STATSD_PORT')
end

After creating a sensor that designates a metric namespace, you can write values to it:

require 'seismograph'

def sensor
  @_sensor ||= Seismograph::Sensor.new('account')
end

def create
  users_to_create = [user1, user_2]

  sensor.count('signup', users_to_create.size) do
    # If an error is raised, the 'account.signup.failure' metric will be incremented instead
    User.create!(users_to_create)
  end
end

Counting:

Counting is useful for tracking simple quantities or events. It accepts a numeric value (default is 1) and an optional block. In addition to counting, this method will also track success or failure (via incrementing) depending on whether an error is raised.

sensor.count('signup', 2)

sensor.count('signup') do
  User.create!(attributes)
end

Benchmarking:

Benchmarking is useful for tracking how long an operation takes. In addition to tracking the timing, this method will also track success or failure (via incrementing) depending on whether an error is raised.

def create
  sensor.benchmark('signup') do
    # Timing will be written for the account.signup metric
    User.create!(params)
  end
end

Timing:

Timing is useful for tracking how long an operation takes, when that operation has already been run. For example, in the subscriber to an ActiveSupport::Instrumentation event. Expects the duration argument to be in ms (which the ActiveSupport event.duration already is).

class ActiveJobSubscriber < ActiveSupport::Subscriber

  attach_to :active_job

  def perform(event)
    job = event.payload[:job]
    tags = ["jobs:#{job.name}", "queue:#{job.queue_name}"]

    sensor.timing "perform", event.duration, sample_rate: 0.5, tags: tags
  end

  def sensor
    @sensor ||= Seismograph::Sensor.new("active_job")
  end

end

Incrementing/Decrementing:

Simple incrementing and decrementing can be performed on a stat. Both methods accept a numeric value (default is 1).

sensor.increment('memberships')
sensor.decrement('memberships', 2)

Gauge:

Gauge is meant for static numbers that you want to track over time (as opposed to a rate for which you would use #count).

sensor.gauge('collection_count', Collection.count)

Logging events:

Logging can be used for tracking critical events. Valid log methods are info, warning, error, and success.

task :deploy do
  begin
    deploy!
    Seismograph::Log.info('App Deployed')
  rescue StandardError => e
    Seismograph::Log.error('Deployment failed!', description: e.message)
  end
end

Test Environment:

To disable seismograph in your test environment, include this file in your test helper:

require 'seismograph/testing'

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request