2014-05-03 01:14:39 +04:00
|
|
|
package tabletserver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/youtube/vitess/go/vt/servenv"
|
|
|
|
)
|
|
|
|
|
|
|
|
// This file contains the status web page export for tabletserver
|
|
|
|
|
|
|
|
var queryserviceStatusTemplate = `
|
|
|
|
State: {{.State}}<br>
|
|
|
|
<div id="qps_chart">QPS: {{.CurrentQPS}}</div>
|
|
|
|
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
|
|
|
google.load("jquery", "1.4.0");
|
|
|
|
google.load("visualization", "1", {packages:["corechart"]});
|
|
|
|
|
|
|
|
function minutesAgo(d, i) {
|
|
|
|
var copy = new Date(d);
|
|
|
|
copy.setMinutes(copy.getMinutes() - i);
|
|
|
|
return copy
|
|
|
|
}
|
|
|
|
|
|
|
|
function drawQPSChart() {
|
|
|
|
var div = $('#qps_chart').height(500).width(900).unwrap()[0]
|
|
|
|
var chart = new google.visualization.LineChart(div);
|
|
|
|
|
|
|
|
var options = {
|
|
|
|
title: "QPS",
|
|
|
|
focusTarget: 'category',
|
|
|
|
vAxis: {
|
|
|
|
viewWindow: {min: 0},
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-02-04 03:55:03 +03:00
|
|
|
// If we're accessing status through a proxy that requires a URL prefix,
|
|
|
|
// add the prefix to the vars URL.
|
|
|
|
var vars_url = '/debug/vars';
|
|
|
|
var pos = window.location.pathname.lastIndexOf('/debug/status');
|
|
|
|
if (pos > 0) {
|
|
|
|
vars_url = window.location.pathname.substring(0, pos) + vars_url;
|
|
|
|
}
|
2014-05-03 01:14:39 +04:00
|
|
|
|
|
|
|
var redraw = function() {
|
2015-02-04 03:55:03 +03:00
|
|
|
$.getJSON(vars_url, function(input_data) {
|
2014-05-03 01:14:39 +04:00
|
|
|
var now = new Date();
|
|
|
|
var qps = input_data.QPS;
|
|
|
|
var planTypes = Object.keys(qps);
|
|
|
|
if (planTypes.length === 0) {
|
|
|
|
planTypes = ["All"];
|
|
|
|
qps["All"] = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
var data = [["Time"].concat(planTypes)];
|
|
|
|
|
|
|
|
for (var i = 0; i < 15; i++) {
|
|
|
|
var datum = [minutesAgo(now, i)];
|
|
|
|
for (var j = 0; j < planTypes.length; j++) {
|
|
|
|
if (i < qps.All.length) {
|
|
|
|
datum.push(+qps[planTypes[j]][i].toFixed(2));
|
|
|
|
} else {
|
|
|
|
datum.push(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
data.push(datum)
|
|
|
|
}
|
|
|
|
chart.draw(google.visualization.arrayToDataTable(data), options);
|
|
|
|
})
|
|
|
|
};
|
|
|
|
|
|
|
|
redraw();
|
|
|
|
|
|
|
|
// redraw every 30 seconds.
|
|
|
|
window.setInterval(redraw, 30000);
|
|
|
|
}
|
|
|
|
google.setOnLoadCallback(drawQPSChart);
|
|
|
|
</script>
|
|
|
|
|
|
|
|
`
|
|
|
|
|
|
|
|
type queryserviceStatus struct {
|
|
|
|
State string
|
|
|
|
CurrentQPS float64
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddStatusPart registers the status part for the status page.
|
|
|
|
func AddStatusPart() {
|
|
|
|
servenv.AddStatusPart("Queryservice", queryserviceStatusTemplate, func() interface{} {
|
|
|
|
status := queryserviceStatus{
|
|
|
|
State: SqlQueryRpcService.GetState(),
|
|
|
|
}
|
2015-01-06 20:37:34 +03:00
|
|
|
rates := qpsRates.Get()
|
2014-05-03 01:14:39 +04:00
|
|
|
if qps, ok := rates["All"]; ok && len(qps) > 0 {
|
|
|
|
status.CurrentQPS = qps[0]
|
|
|
|
|
|
|
|
}
|
|
|
|
return status
|
|
|
|
})
|
|
|
|
}
|