Project

kanshi

0.01
No commit activity in last 3 years
No release in over 3 years
Prints Postgres database metrics to your log stream
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

>= 0
~> 0.2
~> 3.0
 Project Readme

監視

Purpose

Kanshi watches your Postgres database and reports metrics to the log stream. You can then drain this log to an application (or provide your own reporter class) to send these metrics to a service, like Librato or Splunk.

Installation

Kanshi will work as a gem or as a standalone app.

Add to existing app on Heroku

  1. Add Kanshi to your Gemfile:

        gem 'kanshi', :require => false
    
  2. Add Kanshi to your Procfile:

        kanshi: bundle exec kanshi
    
  3. Run bundle install, commit, and deploy.

  4. heroku scale kanshi=1

Create as separate Heroku app

  1. Create a new app.
  2. Follow steps 1-3 from above.
  3. Add environment variables for each database URL you want to monitor.
  4. heroku scale kanshi=1

Custom install

You can create your own version of bin/kanshi to run Kanshi in any way of your choosing, e.g. monitor specific databases or provide your own reporter for output. An easy way to do this would be to create a Rake task to run Kanshi.

For more information, see the Configuration section below and the source code for bin/kanshi.

Configuration

If using the kanshi binary, configuration is optional but is done through environment variables:

  • Kanshi will monitor all postgres:// URLs in your environment.
  • KANSHI_PREFIX will change the prefix used on metrics. Default: kanshi
  • KANSHI_SAMPLE_DELAY will change how often Kanshi monitors your database in seconds. Default: 60. This is the recommended time so that your metrics are reported on a "per minute" basis (metrics are not yet normalized per time period, so changing this value will significantly affect metric values).

Environment variables have no effect on the Kanshi library code, so if executing Kanshi manually, configuration is done via the options hash passed to Kanshi.run:

  • :databases: A hash of database names to URLs ({String => String})
  • :delay: The delay between samples (Fixnum). Default: 300.
  • :reporter: A Class that responds to #report to recieve metrics (Class). Default: Kanshi::ScrollsReporter.

Name

Kanshi (監視) is Japanese for surveillance.