-
Notifications
You must be signed in to change notification settings - Fork 34
Monitoring Background Workers
Both librato-rails and librato-rack are designed to operate inside a long-running process where they can queue up measurements and then periodically submit them in the background.
This model doesn't work well with background workers that run intermittently, exist for variable lengths of time, or fork. If you are using delayed_job, resque, croned or scheduled rake tasks, or queue_classic (forking) you should disable librato-rails
or librato-rack
if they are loading and use an alternate strategy for adding metrics.
Set LIBRATO_AUTORUN=0 in your environment before starting your worker processes and librato-rails
and librato-rack
will never report measurements. You may still have access to the collector methods from these libraries (Librato.increment
, etc) but you shouldn't use them as metrics gathered that way will be lost.
There are a few options to consider when instrumenting your workers:
librato-metrics is a lower-level gem that gives you easy access to the Librato API. You can easily queue up simple metrics, aggregate info for frequently occurring ops locally before sending and more.
If your workers take a while to run you can submit periodically while doing work or if they are short-lived you can use an at_exit handler to ensure metrics are submitted right before the process exits.
Pros: Works anywhere, just ruby, no extra process to run, lots of control
Cons: May add a small amount of time to worker exit as metrics are submitted
statsd is a tiny node-based daemon that you can run as a separate process and send UDP packets to as your workers run. We have a Librato plugin that makes it easy to hook up.
This offloads all the work of submission to the statsd daemon so when your workers start or exit doesn't matter anymore.
Pros: Extremely fast, no delay in workers exiting
Cons: You need to run another process
If you are on heroku you can't run your own other independent processes so statsd is out. Start with librato-metrics and if you find the performance profile isn't a good fit, send us an email to find out more about some alternative options we're working on.
If you are using sidekiq or queue_classic (threaded), librato-rails
or librato-rack
may actually be a good fit for your workers. Be sure to configure using the ENV-variable strategy as your workers may not be able to find your yaml-based config files.
Newer versions of librato-rails
and librato-rack
don't start the background reporter until the process receives its first request. Since your workers will most likely not ever see any requests you need to let the library know to start up the reporter:
TODO: document further s/p lib-rails 0.10.0