Team Dashboard lets you visualize your team's metrics all in one place (see Screenshot). It is build to be shown on a big screen in your team's space.
It has built-in support for Graphite and makes it really easy to add more input sources.
It is implemented as a Rails app and uses MySQL to store your custom dashboards configuration.
Support via Team Dashboard Google Group
Thanks go to Martin Tschischauskas and Marno Krahmer who worked with me on the first iteration which was build as part of a XING Hackathon Project.
Clone the repository:
git clone git://github.com/fdietz/team_dashboard.git
Run bundler:
bundle install
Create a database.yml from the example config:
cp config/database.example.yml config/database.yml
Create the database and run migrations:
rake db:create && rake db:migrate
There is an initial "Demo" source and sample dashboards provided. Generate these via:
rake populate
Start the Rails server:
rails s
You have to configure the MySQL database in config/database.yml.
Graphite is the first input source Team Dashboard supports. Use the environment variable GRAPHITE_URL or change the rails configuration (see application.rb and environment specific files) directly.
GRAPHITE_URL=http://mygraphiteserver
For example:
GRAPHITE_URL=http://localhost:8080 rails s
A dashboard in Team Dashboard consists of multiple Widgets, which request data from a data source via AJAX request.
All widgets have a name, time interval in which to update themselves and a data source as a common configuration.
The graph widget shows a time series line graph (using rickshaw.js internally). Use it to show number of visits on your web page or number of currently online users and follow-up on trends.
It currently supports a Demo data source, Graphite and the http proxy source.
Name | Documentation |
---|---|
Date Range/Period | Select a date range of for example "Last 3 hours" |
Size | Number of Columns (Possible Values: 1, 2 or 3) |
Graph Type | Either a line or stacked graph. |
Data Source | Only "demo" and "graphite" currently supported. |
Targets | Comma-separated targets. Also supports wildcards (example: visits.server.*). |
Shows the current value and the percentage of change of the last period. It is based on time series data and uses the same data sources as the graph widget. The widgets supports showing two values. Use it to for example show the current number of online users.
It currently supports a Demo data source, Graphite and the http proxy source.
Name | Documentation |
---|---|
Date Range/Period | Select a date range of for example "Last 3 hours" |
Size | Number of Columns (Possible Values: 1, 2 or 3) |
Data Source | Only "demo" and "graphite" currently supported. |
Targets | Comma-separated targets. Also supports wildcards (example: visits.server.*). |
Aggregate Function | The values of the selected period are aggregated using selected function. Supports sum, average and delta. |
Shows the current integer value provided by the data source and a label. The widget supports up to three values. Use it to show for the example the number of errors on specific system.
It currently supports a demo data source and a http proxy data source.
Name | Documentation |
---|---|
Date Range/Period | Select a date range of for example "Last 3 hours" |
Label | Label for this value |
HTTP Proxy URL | HTTP URL should return a JSON structure as described below |
Shows the current boolean value provided by the data source and an label. The widget supports up to three values. Use it to show for example the success of a Jenkins build.
It currently supports a demo data source and a http proxy data source.
Name | Documentation |
---|---|
Date Range/Period | Select a date range of for example "Last 3 hours" |
Label | Label for this value |
HTTP Proxy URL | HTTP URL should return a JSON structure as described below |
The datapoints source supports data for rendering graphs and aggregated values. Following a minimal implementation.
class Example < Sources::Datapoints::Base
def get(targets, from, to, options = {})
result = []
targets.each do |target|
# retrieve the actual data here
result << { 'target' => "demo.example1", 'datapoints' => [[1, 123456], [7, 123466]] }
end
result
end
end
Note the datapoints array consists of pairs of number values (y-value and timestamp for the x-value of the graph). This is similar to how Graphite or Ganglia structure their json data for graph data.
The number data source supports a single integer value and an optional label.
class Example < Sources::Number::Base
def get(options = {})
# retrieve actual data here
{ :value => 115, :label => "example label" }
end
end
The boolean data source supports a single boolean value and an optional label.
class Example < Sources::Boolean::Base
def get(options = {})
# retrieve actual data here
{ :value => true, :label => "example label" }
end
end
Create a data source ruby file under app/models/sources. As long as it extends from the specific base class (for example Sources::Boolean::Base) it will be automatically available.
As described above you can easily add your own data source implementions. On the other hand you might prefer to offer a service on your server instead. The HTTP proxy source requests data on the server side, the Rails app being the "proxy" of the web app. The JSON format for the specific sources is described below.
The datapoints source supports data for rendering graphs and aggregated values
[
{
"target" : "demo.example",
"datapoints" : [
[1,123456], [7,23466]
]
},
{
"target" : "demo.example2",
"datapoints" : [
[-6,123456], [8,23466]
]
}
]
The number data source supports a single integer value and an optional label.
{
"value" : 8,
"label" : "This is an example label"
}
The boolean data source supports a single boolean value and an optional label.
{
"value" : true,
"label" : "This is an example label"
}
Copyright (c) 2012 Frederik Dietz
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.