2017-08-30 13:47:28 +00:00
|
|
|
/*!
|
|
|
|
* Pi Dashboard (http://www.nxez.com)
|
|
|
|
* Copyright 2017 NXEZ.com.
|
2017-08-30 14:07:42 +00:00
|
|
|
* Licensed under the GPL v3.0 license.
|
2017-08-30 13:47:28 +00:00
|
|
|
*/
|
|
|
|
$(document).ready(function() {
|
|
|
|
Highcharts.setOptions({
|
|
|
|
global: {
|
|
|
|
useUTC: false
|
|
|
|
},
|
|
|
|
credits: {
|
|
|
|
enabled: false
|
|
|
|
},
|
|
|
|
navigation: {
|
|
|
|
buttonOptions: {
|
|
|
|
enabled: false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var gaugeOptions = {
|
|
|
|
|
|
|
|
chart: {
|
|
|
|
type: 'solidgauge'
|
|
|
|
},
|
|
|
|
|
|
|
|
title: null,
|
|
|
|
|
|
|
|
pane: {
|
|
|
|
center: ['50%', '85%'],
|
|
|
|
size: '140%',
|
|
|
|
startAngle: -90,
|
|
|
|
endAngle: 90,
|
|
|
|
background: {
|
|
|
|
backgroundColor: (Highcharts.theme && Highcharts.theme.background2) || '#FFFFFF',
|
|
|
|
innerRadius: '60%',
|
|
|
|
outerRadius: '100%',
|
|
|
|
shape: 'arc'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
tooltip: {
|
|
|
|
enabled: false
|
|
|
|
},
|
|
|
|
|
|
|
|
// the value axis
|
|
|
|
yAxis: {
|
|
|
|
stops: [
|
|
|
|
[0.1, '#55BF3B'],
|
|
|
|
[0.5, '#DDDF0D'],
|
|
|
|
[0.9, '#DF5353']
|
|
|
|
],
|
|
|
|
lineWidth: 0,
|
|
|
|
minorTickInterval: null,
|
|
|
|
tickAmount: 2,
|
|
|
|
title: {
|
|
|
|
y: -70
|
|
|
|
},
|
|
|
|
labels: {
|
|
|
|
y: 16
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
plotOptions: {
|
|
|
|
solidgauge: {
|
|
|
|
dataLabels: {
|
|
|
|
y: 5,
|
|
|
|
borderWidth: 0,
|
|
|
|
useHTML: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
var chartCPU = Highcharts.chart('container-cpu', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: 100,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'CPU',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:28px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y}</span>' +
|
|
|
|
'<span style="font-size:12px;color:silver">%</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' %'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
var chartRAM = Highcharts.chart('container-mem', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: init_vals.mem.total,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'MEMORY',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:25px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y:.1f}</span><br/>' +
|
|
|
|
'<span style="font-size:12px;color:silver">MB</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' MB'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
var chartCache = Highcharts.chart('container-cache', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: init_vals.mem.total,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'CACHE',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:12px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y:.1f}</span><br/>' +
|
|
|
|
'<span style="font-size:10px;color:silver">MB</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' MB'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
var chartRAM_real = Highcharts.chart('container-mem-real', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: init_vals.mem.total,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'REAL MEMORY',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:12px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y:.1f}</span><br/>' +
|
|
|
|
'<span style="font-size:10px;color:silver">MB</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' MB'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
var chartSWAP = Highcharts.chart('container-swap', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: init_vals.mem.swap.total,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'SWAP',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:12px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y:.1f}</span><br/>' +
|
|
|
|
'<span style="font-size:10px;color:silver">MB</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' MB'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
var chartDisk = Highcharts.chart('container-disk', Highcharts.merge(gaugeOptions, {
|
|
|
|
yAxis: {
|
|
|
|
min: 0,
|
|
|
|
max: init_vals.disk.total,
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
series: [{
|
|
|
|
name: 'DISK',
|
|
|
|
data: [0],
|
|
|
|
dataLabels: {
|
|
|
|
format: '<div style="text-align:center"><span style="font-size:12px;color:' +
|
|
|
|
((Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black') + '">{y:.1f}</span><br/>' +
|
|
|
|
'<span style="font-size:10px;color:silver">GB</span></div>'
|
|
|
|
},
|
|
|
|
tooltip: {
|
|
|
|
valueSuffix: ' GB'
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
var chartNetInterfaces = new Array();
|
|
|
|
var net_In = new Array();
|
|
|
|
var net_Out = new Array();
|
|
|
|
for(i=0;i<init_vals.net.count;i++)
|
|
|
|
{
|
|
|
|
var chartNetInterface = Highcharts.chart('container-net-interface-'+(i+1), {
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
},
|
|
|
|
legend: {
|
|
|
|
enabled: false
|
|
|
|
},
|
|
|
|
xAxis: {
|
|
|
|
categories: [],
|
|
|
|
title: {
|
|
|
|
text: ''
|
|
|
|
}
|
|
|
|
},
|
|
|
|
yAxis: {
|
|
|
|
title: {
|
|
|
|
text: '',
|
|
|
|
style: {
|
|
|
|
fontWeight: 'normal'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
series: [
|
|
|
|
{
|
|
|
|
name: 'IN',
|
|
|
|
data: [0],
|
|
|
|
color: '#093AC9'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'OUT',
|
|
|
|
data: [0],
|
|
|
|
color: '#3CCB3E'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
});
|
|
|
|
chartNetInterfaces[i] = chartNetInterface;
|
|
|
|
net_In[i] = [0,0,0,0,0,0,0,0,0,0];
|
|
|
|
net_Out[i] = [0,0,0,0,0,0,0,0,0,0];
|
|
|
|
}
|
|
|
|
|
|
|
|
setInterval(function() {
|
|
|
|
|
|
|
|
$.getJSON('?ajax=true', function(data){
|
|
|
|
|
|
|
|
//console.log(data);
|
|
|
|
var newDate = new Date();
|
|
|
|
newDate.setTime(parseInt(data.time) * 1000);
|
|
|
|
|
|
|
|
$("#time").text(newDate.format('hh:mm:ss'));
|
|
|
|
$("#date").text(newDate.format('yyyy-MM-dd'));
|
|
|
|
$("#uptime").text(uptimeFormat(data.uptime));
|
|
|
|
$("#cpu-temp").text(Math.round(data.cpu.temp/1000 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#mem-percent").text(data.mem.percent);
|
|
|
|
$("#mem-free").text(data.mem.free);
|
|
|
|
$("#mem-cached").text(data.mem.cached);
|
|
|
|
$("#mem-swap-total").text(data.mem.swap.total);
|
|
|
|
$("#mem-cache-percent").text(data.mem.cached_percent);
|
|
|
|
$("#mem-buffers").text(data.mem.buffers);
|
|
|
|
$("#mem-real-percent").text(data.mem.real.percent);
|
|
|
|
$("#mem-real-free").text(data.mem.real.free);
|
|
|
|
$("#mem-swap-percent").text(data.mem.swap.percent);
|
|
|
|
$("#mem-swap-free").text(data.mem.swap.free);
|
|
|
|
$("#disk-percent").text(data.disk.percent);
|
|
|
|
$("#disk-free").text(data.disk.free);
|
|
|
|
$("#loadavg-1m").text(data.load_avg[0]);
|
|
|
|
$("#loadavg-5m").text(data.load_avg[1]);
|
|
|
|
$("#loadavg-10m").text(data.load_avg[2]);
|
|
|
|
$("#loadavg-running").text(data.load_avg[3].split("/")[0]);
|
|
|
|
$("#loadavg-threads").text(data.load_avg[3].split("/")[1]);
|
|
|
|
|
|
|
|
|
|
|
|
for(i=0;i<data.net.count;i++)
|
|
|
|
{
|
|
|
|
$("#net-interface-"+(i+1)+"-total-in").text(bytesRound(parseInt(data.net.interfaces[i].total_in), 2));
|
|
|
|
$("#net-interface-"+(i+1)+"-total-out").text(bytesRound(parseInt(data.net.interfaces[i].total_out), 2));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(window.dashboard != null)
|
|
|
|
{
|
|
|
|
window.dashboard_old = window.dashboard;
|
|
|
|
}
|
|
|
|
|
|
|
|
window.dashboard = data;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
if(window.dashboard != null){
|
|
|
|
//console.log(window.dashboard);
|
|
|
|
|
|
|
|
// Speed
|
|
|
|
var point;
|
|
|
|
// newVal,
|
|
|
|
// inc;
|
|
|
|
|
|
|
|
if (chartRAM) {
|
|
|
|
point = chartRAM.series[0].points[0];
|
|
|
|
point.update(window.dashboard.mem.used);
|
|
|
|
}
|
|
|
|
if (chartCache) {
|
|
|
|
point = chartCache.series[0].points[0];
|
|
|
|
point.update(window.dashboard.mem.cached);
|
|
|
|
}
|
|
|
|
if (chartRAM_real) {
|
|
|
|
point = chartRAM_real.series[0].points[0];
|
|
|
|
point.update(window.dashboard.mem.real.used);
|
|
|
|
}
|
|
|
|
if (chartSWAP) {
|
|
|
|
point = chartSWAP.series[0].points[0];
|
|
|
|
point.update(window.dashboard.mem.swap.used);
|
|
|
|
}
|
|
|
|
if (chartDisk) {
|
|
|
|
point = chartDisk.series[0].points[0];
|
|
|
|
point.update(window.dashboard.disk.used);
|
|
|
|
/*
|
|
|
|
inc = Math.random() - 0.5;
|
|
|
|
newVal = point.y + inc;
|
|
|
|
|
|
|
|
if (newVal < 0 || newVal > 5) {
|
|
|
|
newVal = point.y - inc;
|
|
|
|
}
|
|
|
|
|
|
|
|
point.update(newVal);
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
if(window.dashboard_old != null)
|
|
|
|
{
|
|
|
|
//console.log(window.dashboard_old.net.count);
|
|
|
|
if(window.dashboard_old.net.count > 0)
|
|
|
|
{
|
|
|
|
for(i=0;i<window.dashboard_old.net.count;i++)
|
|
|
|
{
|
|
|
|
if(chartNetInterfaces[i].series[0].data.length >=30){
|
|
|
|
chartNetInterfaces[i].series[0].addPoint(parseInt(window.dashboard.net.interfaces[i].total_in) - parseInt(window.dashboard_old.net.interfaces[i].total_in), true, true);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
chartNetInterfaces[i].series[0].addPoint(parseInt(window.dashboard.net.interfaces[i].total_in) - parseInt(window.dashboard_old.net.interfaces[i].total_in));
|
|
|
|
}
|
|
|
|
|
|
|
|
if(chartNetInterfaces[i].series[1].data.length >=30){
|
|
|
|
chartNetInterfaces[i].series[1].addPoint(parseInt(window.dashboard.net.interfaces[i].total_out) - parseInt(window.dashboard_old.net.interfaces[i].total_out), true, true);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
chartNetInterfaces[i].series[1].addPoint(parseInt(window.dashboard.net.interfaces[i].total_out) - parseInt(window.dashboard_old.net.interfaces[i].total_out));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
idle_diff = parseInt(window.dashboard.cpu.stat.idle) - parseInt(window.dashboard_old.cpu.stat.idle);
|
|
|
|
used_total = parseInt(window.dashboard.cpu.stat.idle) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.user) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.sys) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.nice) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.iowait) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.irq) +
|
|
|
|
parseInt(window.dashboard.cpu.stat.softirq) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.idle) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.user) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.sys) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.nice) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.iowait) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.irq) -
|
|
|
|
parseInt(window.dashboard_old.cpu.stat.softirq);
|
|
|
|
|
|
|
|
if (chartCPU) {
|
|
|
|
point = chartCPU.series[0].points[0];
|
|
|
|
point.update(Math.round((1.0 - (idle_diff / used_total)) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$("#cpu-stat-idl").text(Math.round(((parseInt(window.dashboard.cpu.stat.idle) - parseInt(window.dashboard_old.cpu.stat.idle)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-use").text(Math.round(((parseInt(window.dashboard.cpu.stat.user) - parseInt(window.dashboard_old.cpu.stat.user)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-sys").text(Math.round(((parseInt(window.dashboard.cpu.stat.sys) - parseInt(window.dashboard_old.cpu.stat.sys)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-nic").text(Math.round(((parseInt(window.dashboard.cpu.stat.nice) - parseInt(window.dashboard_old.cpu.stat.nice)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-iow").text(Math.round(((parseInt(window.dashboard.cpu.stat.iowait) - parseInt(window.dashboard_old.cpu.stat.iowait)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-irq").text(Math.round(((parseInt(window.dashboard.cpu.stat.irq) - parseInt(window.dashboard_old.cpu.stat.irq)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
$("#cpu-stat-sirq").text(Math.round(((parseInt(window.dashboard.cpu.stat.softirq) - parseInt(window.dashboard_old.cpu.stat.softirq)) / used_total) * 100 * Math.pow(10,1))/Math.pow(10,1));
|
|
|
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, 1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
function bytesRound(number, round)
|
|
|
|
{
|
|
|
|
if (number<0){
|
|
|
|
var last=0+"B";
|
|
|
|
}else if (number<1024){
|
|
|
|
//var last=Math.round(number*Math.pow(10,round))/Math.pow(10,round)+"B";
|
|
|
|
var last=number+"B";
|
|
|
|
}else if (number<1048576){
|
|
|
|
number=number/1024;
|
|
|
|
var last=Math.round(number*Math.pow(10,round))/Math.pow(10,round)+"K";
|
|
|
|
}else if (number<1048576000){
|
|
|
|
number=number/1048576;
|
|
|
|
var last=Math.round(number*Math.pow(10,round))/Math.pow(10,round)+"M";
|
|
|
|
}else{
|
|
|
|
number=number/1048576000;
|
|
|
|
var last=Math.round(number*Math.pow(10,round))/Math.pow(10,round)+"G";
|
|
|
|
}
|
|
|
|
return last;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Date.prototype.format = function(format) {
|
|
|
|
var date = {
|
|
|
|
"M+": this.getMonth() + 1,
|
|
|
|
"d+": this.getDate(),
|
|
|
|
"h+": this.getHours(),
|
|
|
|
"m+": this.getMinutes(),
|
|
|
|
"s+": this.getSeconds(),
|
|
|
|
"q+": Math.floor((this.getMonth() + 3) / 3),
|
|
|
|
"S+": this.getMilliseconds()
|
|
|
|
};
|
|
|
|
if (/(y+)/i.test(format)) {
|
|
|
|
format = format.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length));
|
|
|
|
}
|
|
|
|
for (var k in date) {
|
|
|
|
if (new RegExp("(" + k + ")").test(format)) {
|
|
|
|
format = format.replace(RegExp.$1, RegExp.$1.length == 1
|
|
|
|
? date[k] : ("00" + date[k]).substr(("" + date[k]).length));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return format;
|
|
|
|
}
|
|
|
|
|
|
|
|
function uptimeFormat(str){
|
|
|
|
var uptime = "";
|
|
|
|
var min = parseInt(str) / 60;
|
|
|
|
var hours = min / 60;
|
|
|
|
var days = Math.floor(hours / 24);
|
|
|
|
var hours = Math.floor(hours - (days * 24));
|
|
|
|
min = Math.floor(min - (days * 60 * 24) - (hours * 60));
|
|
|
|
|
|
|
|
if (days !== 0){
|
|
|
|
if(days == 1){
|
|
|
|
uptime = days+" day ";
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
uptime = days+" days ";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (hours !== 0){
|
|
|
|
uptime = uptime+hours+":";
|
|
|
|
}
|
|
|
|
|
|
|
|
return uptime=uptime+min;
|
|
|
|
}
|