This is a fork of the original Tasseo project that doesn't require Ruby. The goal was to integrate Tasseo into an existing graphite installation.
Open the graphite/graphite-install.sh file and set GRAPHITE_DIR to the path of your graphite installation. Run the graphite-install.sh script and that should be it.
- No need for Ruby
- Integrates into your existing Graphite installation
- You don't need to create dashboard javascript files if you don't want. Simply create a graph in graphite composer and get your URL:
http://graphite_url/render/?target=alias(some.stat%2C%22stat1_alias%22)&target=some.stat.no.alias
and then just replacerender
withtasseo
so your new URL ishttp://graphite_url/tasseo/?target=alias(some.stat%2C%22stat1_alias%22)&target=some.stat.no.alias
- you can also add some additional parameters into the URL that will affect all the graphs:
- unit=%
- warning=X
- critical=Y
- default_period=Z :: where Z is in minutes
- if your targets are defined with an alias() function then tasseo will use the alias name otherwise it will just use the stat name
- you can also add some additional parameters into the URL that will affect all the graphs:
- Tasseo javascript dashboards are still supported, just put them into
$GRAPHITE_DIR/content/tasseo/d
Reading the tea leaves.
Tasseo is a lightweight, easily configurable, real-time dashboard for Graphite events. Charts are refreshed every two seconds and provide a heads-up view of the most current value.
The default behavior is designed for a Carbon retention policy with a 1-second resolution for at least 5 minutes, although this can be modified within the dashboard and metric attributes.
Creating your own dashboard is as simple as dropping a JSON file into the public/d
directory, committing it, and pushing the code to a Heroku app. The name of your file (minus the .js
suffix) becomes the name of your dashboard. Here's an example configuration that you could put in e.g. public/d/example.js
:
var metrics =
[
{
"alias": "pulse-events-per-second",
"target": "pulse.pulse-events-per-second",
"warning": 100,
"critical": 500
}
];
The target
attribute is the only mandatory field. As you might expect, each dashboard can contain an arbitrary list of different Graphite metrics. Another perfectly valid example:
var metrics =
[
{ "target": "pulse.hermes-econns-apps-per-minute" },
{ "target": "pulse.hermes-econns-per-minute" },
{ "target": "pulse.hermes-elevated-route-lookups-per-minute" },
{ "target": "pulse.hermes-errors-per-minute" },
{ "target": "pulse.hermes-h10-per-minute" },
{ "target": "pulse.hermes-h11-per-minute" },
{ "target": "pulse.hermes-h12-per-minute" },
{ "target": "pulse.hermes-h13-per-minute" },
{ "target": "pulse.hermes-h14-per-minute" },
{ "target": "pulse.hermes-h18-per-minute" },
{ "target": "pulse.hermes-h99-per-minute" }
];
As an alternative to static dashboard layouts, it's possible to use a false
target to pad cells on the dashboard grid. Because metrics are read in a predictable manner from their respective .js
files, this provides a mechanism for organizing an otherwise uncontrollable layout.
var metrics =
[
{ "target": "foo" },
{ "target": false },
{ "target": "bar" }
];
warning
and critical
thresholds are optional. If defined, the color of the graph will change when the current value exceeds the respective threshold. If the thresholds are reversed (i.e. critical
is lower than warning
), Tasseo understands that an inverse threshold is expected.
- period - Range (in minutes) of data to query from Graphite. (optional, defaults to 5)
- refresh - Refresh interval for charts, in milliseconds. (optional, defaults to 2000)
- theme - Default theme for dashboard. Currently the only option is
dark
. (optional) - toolbar - Dictates whether the toolbar is shown or not. (optional, defaults to true)
- alias - Short name for the metric. (optional)
- target - Full target name as used by Graphite. Can contain a combination of chained functions. (mandatory)
- warning - Warning threshold. Exceeding this value causes the graph to turn yellow. (optional)
- critical - Critical threshold. Exceeding this value causes the graph to turn red. (optional)
- unit - Arbitrary string that can be used to designate a unit value; for example, "Mbps". (optional)
The only required environment variable is GRAPHITE_URL
. This should be set to the base URL of your Graphite composer (e.g. https://graphite.yourdomain.com
). If your server requires Basic Auth, you can set the GRAPHITE_AUTH
variable (e.g. username:password
).
$ rvm use 1.9.2
$ bundle install
$ export GRAPHITE_URL=...
$ export GRAPHITE_AUTH=... # e.g. username:password (optional)
$ foreman start
$ open http://127.0.0.1:5000
$ export DEPLOY=production/staging/you
$ heroku create -r $DEPLOY -s cedar tasseo-$DEPLOY
$ heroku config:set -r $DEPLOY GRAPHITE_URL=...
$ heroku config:set -r $DEPLOY GRAPHITE_AUTH=...
$ git push $DEPLOY master
$ heroku scale -r $DEPLOY web=1
$ heroku open -r $DEPLOY
In order to support CORS with JSON instead of JSONP, we need to allow specific headers and allow the cross-domain origin request. The following are suggested settings for Apache 2.x. Adjust as necessary for your environment or webserver.
Header set Access-Control-Allow-Origin "*"
Header set Access-Control-Allow-Methods "GET, OPTIONS"
Header set Access-Control-Allow-Headers "origin, authorization, accept"
Tasseo is distributed under a 3-clause BSD license. Third-party software libraries included with this project are distributed under their respective licenses.
- d3.js - 3-clause BSD
- Rickshaw - MIT