RailsRiemannMiddleware
A middleware to add to your rails application that sends request duration metrics and exception notifications to Riemann.
Installation
Add this line to your application's Gemfile:
gem 'rails_riemann_middleware'
And then execute:
$ bundle
Or install it yourself as:
$ gem install rails_riemann_middleware
Usage
Add the following to your specific rails enviroment.
config.riemann_options = (:riemann_host => "riemann_host_name")
config.middleware.use(RailsRiemannMiddleware::Notifier,
config.riemann_options)
If you would like to pull custom headers out of the env for reporting, you can add
:additional_headers => ['SOME_HEADER', 'SOME_OTHER_HEADER']
Those will be reported for both exceptions and duration events. If the header is not defined, it will be reported as 'N/A'.
ExceptionNotification 3.x API
If you, like us, are transitioning from the exception_notification gem, we support the API from the 3.x version of that gem for explicit calls to the exception notifier. For example, if you are catching exceptions in your controllers (preventing them from bubbling up automatically), you can call:
RailsRiemannMiddleware::RailsExceptionNotifier.exception_notification(env, error)
In your models or other background processes, you can call:
RailsRiemannMiddleware::RailsExceptionNotifier.background_exception_notification(error)
To use this extra functionality, you have to
require 'rails_riemann_middleware/rails_exception_notifier'
Running Tests
To run the tests use:
$ bundle exec rake test
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request