Remove old metrics dashboard
It only applies to a single instance, making it fairly useless
This commit is contained in:
parent
b979f99964
commit
5d6876eb81
5 changed files with 1 additions and 189 deletions
|
@ -4,63 +4,14 @@ import json
|
||||||
from flask import request, Blueprint, abort, Response
|
from flask import request, Blueprint, abort, Response
|
||||||
from flask.ext.login import current_user
|
from flask.ext.login import current_user
|
||||||
from auth.auth import require_session_login
|
from auth.auth import require_session_login
|
||||||
from endpoints.common import route_show_if
|
from app import userevents
|
||||||
from app import app, userevents
|
|
||||||
from auth.permissions import SuperUserPermission
|
|
||||||
from data.userevent import CannotReadUserEventsException
|
from data.userevent import CannotReadUserEventsException
|
||||||
|
|
||||||
import features
|
|
||||||
import psutil
|
|
||||||
import time
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
realtime = Blueprint('realtime', __name__)
|
realtime = Blueprint('realtime', __name__)
|
||||||
|
|
||||||
|
|
||||||
@realtime.route("/ps")
|
|
||||||
@route_show_if(features.SUPER_USERS)
|
|
||||||
@require_session_login
|
|
||||||
def ps():
|
|
||||||
if not SuperUserPermission().can():
|
|
||||||
abort(403)
|
|
||||||
|
|
||||||
def generator():
|
|
||||||
while True:
|
|
||||||
build_status = {}
|
|
||||||
try:
|
|
||||||
builder_data = app.config['HTTPCLIENT'].get('http://localhost:8686/status', timeout=1)
|
|
||||||
if builder_data.status_code == 200:
|
|
||||||
build_status = json.loads(builder_data.text)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
try:
|
|
||||||
data = {
|
|
||||||
'count': {
|
|
||||||
'cpu': psutil.cpu_percent(interval=1, percpu=True),
|
|
||||||
'virtual_mem': psutil.virtual_memory(),
|
|
||||||
'swap_mem': psutil.swap_memory(),
|
|
||||||
'connections': len(psutil.net_connections()),
|
|
||||||
'processes': len(psutil.pids()),
|
|
||||||
'network': psutil.net_io_counters()
|
|
||||||
},
|
|
||||||
'build': build_status
|
|
||||||
}
|
|
||||||
except psutil.AccessDenied:
|
|
||||||
data = {}
|
|
||||||
|
|
||||||
json_string = json.dumps(data)
|
|
||||||
yield 'data: %s\n\n' % json_string
|
|
||||||
time.sleep(1)
|
|
||||||
|
|
||||||
try:
|
|
||||||
return Response(generator(), mimetype="text/event-stream")
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@realtime.route("/user/")
|
@realtime.route("/user/")
|
||||||
@require_session_login
|
@require_session_login
|
||||||
def index():
|
def index():
|
||||||
|
|
|
@ -1,75 +0,0 @@
|
||||||
<div class="ps-usage-graph-element">
|
|
||||||
<!-- Build Charts -->
|
|
||||||
<div quay-show="Features.BUILD_SUPPORT">
|
|
||||||
<div class="alert alert-warning" ng-if="data.build && data.build.job_total == null">
|
|
||||||
Cannot load build system status. Please restart your container.
|
|
||||||
</div>
|
|
||||||
<div ng-if="data.build && data.build.job_total >= 0">
|
|
||||||
<div class="col-md-6 chart-col">
|
|
||||||
<h4>Build Queue</h4>
|
|
||||||
<h5>
|
|
||||||
Running Jobs: {{ data.build.running_total }} | Total Jobs: {{ data.build.job_total }}
|
|
||||||
</h5>
|
|
||||||
<div class="realtime-area-chart"
|
|
||||||
data="[data.build.job_total, data.build.running_total]"
|
|
||||||
labels="['Queued Build Jobs', 'Running Build Jobs']"
|
|
||||||
colors="['rgb(157, 194, 211)', 'rgb(56, 122, 163)']"
|
|
||||||
counter="counter"
|
|
||||||
minimum="-10"
|
|
||||||
maximum="auto"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-6 chart-col">
|
|
||||||
<h4>Local Build Workers</h4>
|
|
||||||
<h5>
|
|
||||||
Local Workers: {{ data.build.workers }} | Working: {{ data.build.running_local }}
|
|
||||||
</h5>
|
|
||||||
<div class="realtime-area-chart"
|
|
||||||
data="[data.build.job_total, data.build.workers, data.build.running_local]"
|
|
||||||
labels="['Queued Build Jobs', 'Build Workers (local)', 'Running Build Jobs (local)']"
|
|
||||||
colors="['rgb(157, 194, 211)', 'rgb(161, 208, 93)', 'rgb(210, 237, 130)']"
|
|
||||||
counter="counter"
|
|
||||||
minimum="-10"
|
|
||||||
maximum="auto"></div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- CPU, Memory and Network -->
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>CPU Usage %</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.cpu" counter="counter"
|
|
||||||
label-template="CPU #{x} %"
|
|
||||||
minimum="-10" maximum="110"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>Process Count</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.processes" counter="counter"
|
|
||||||
label-template="Process Count"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>Virtual Memory %</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.virtual_mem[2]" counter="counter"
|
|
||||||
label-template="Virtual Memory %"
|
|
||||||
minimum="-10" maximum="110"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>Swap Memory</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.swap_mem[3]" counter="counter"
|
|
||||||
label-template="Swap Memory %"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>Network Connections</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.connections" counter="counter"
|
|
||||||
label-template="Network Connection Count"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="col-md-4 chart-col">
|
|
||||||
<h4>Network Usage (Bytes)</h4>
|
|
||||||
<div class="realtime-line-chart" data="data.count.network" labels="['Bytes In', 'Bytes Out']" counter="counter"></div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
|
@ -1,50 +0,0 @@
|
||||||
/**
|
|
||||||
* An element which displays charts and graphs representing the current installation of the
|
|
||||||
* application. This control requires superuser access and *must be disabled when not visible*.
|
|
||||||
*/
|
|
||||||
angular.module('quay').directive('psUsageGraph', function () {
|
|
||||||
var directiveDefinitionObject = {
|
|
||||||
priority: 0,
|
|
||||||
templateUrl: '/static/directives/ps-usage-graph.html',
|
|
||||||
replace: false,
|
|
||||||
transclude: false,
|
|
||||||
restrict: 'C',
|
|
||||||
scope: {
|
|
||||||
'isEnabled': '=isEnabled'
|
|
||||||
},
|
|
||||||
controller: function($scope, $element) {
|
|
||||||
$scope.counter = -1;
|
|
||||||
$scope.data = null;
|
|
||||||
|
|
||||||
var source = null;
|
|
||||||
|
|
||||||
var connect = function() {
|
|
||||||
if (source) { return; }
|
|
||||||
source = new EventSource('/realtime/ps');
|
|
||||||
source.onmessage = function(e) {
|
|
||||||
$scope.$apply(function() {
|
|
||||||
$scope.counter++;
|
|
||||||
$scope.data = JSON.parse(e.data);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
var disconnect = function() {
|
|
||||||
if (!source) { return; }
|
|
||||||
source.close();
|
|
||||||
source = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
$scope.$watch('isEnabled', function(value) {
|
|
||||||
if (value) {
|
|
||||||
connect();
|
|
||||||
} else {
|
|
||||||
disconnect();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$scope.$on("$destroy", disconnect);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
return directiveDefinitionObject;
|
|
||||||
});
|
|
|
@ -29,15 +29,10 @@
|
||||||
$scope.pollChannel = null;
|
$scope.pollChannel = null;
|
||||||
$scope.logsScrolled = false;
|
$scope.logsScrolled = false;
|
||||||
$scope.csrf_token = encodeURIComponent(window.__token);
|
$scope.csrf_token = encodeURIComponent(window.__token);
|
||||||
$scope.dashboardActive = false;
|
|
||||||
$scope.currentConfig = null;
|
$scope.currentConfig = null;
|
||||||
$scope.serviceKeysActive = false;
|
$scope.serviceKeysActive = false;
|
||||||
$scope.takeOwnershipInfo = null;
|
$scope.takeOwnershipInfo = null;
|
||||||
|
|
||||||
$scope.setDashboardActive = function(active) {
|
|
||||||
$scope.dashboardActive = active;
|
|
||||||
};
|
|
||||||
|
|
||||||
$scope.configurationSaved = function(config) {
|
$scope.configurationSaved = function(config) {
|
||||||
$scope.currentConfig = config;
|
$scope.currentConfig = config;
|
||||||
$scope.requiresRestart = true;
|
$scope.requiresRestart = true;
|
||||||
|
|
|
@ -28,10 +28,6 @@
|
||||||
tab-target="#servicekeys" tab-init="loadServiceKeys()">
|
tab-target="#servicekeys" tab-init="loadServiceKeys()">
|
||||||
<i class="fa fa-key"></i>
|
<i class="fa fa-key"></i>
|
||||||
</span>
|
</span>
|
||||||
<span class="cor-tab" tab-title="Dashboard" tab-target="#dashboard"
|
|
||||||
tab-shown="setDashboardActive(true)" tab-hidden="setDashboardActive(false)">
|
|
||||||
<i class="fa fa-tachometer"></i>
|
|
||||||
</span>
|
|
||||||
<span class="cor-tab" tab-title="Change Log" tab-target="#change-log" tab-init="getChangeLog()">
|
<span class="cor-tab" tab-title="Change Log" tab-target="#change-log" tab-init="getChangeLog()">
|
||||||
<i class="fa fa-rss"></i>
|
<i class="fa fa-rss"></i>
|
||||||
</span>
|
</span>
|
||||||
|
@ -59,11 +55,6 @@
|
||||||
<div class="service-keys-manager" is-enabled="serviceKeysActive"></div>
|
<div class="service-keys-manager" is-enabled="serviceKeysActive"></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- Dashboard tab -->
|
|
||||||
<div id="dashboard" class="tab-pane">
|
|
||||||
<div class="ps-usage-graph" is-enabled="dashboardActive"></div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Debugging tab -->
|
<!-- Debugging tab -->
|
||||||
<div id="debug" class="tab-pane">
|
<div id="debug" class="tab-pane">
|
||||||
<div class="cor-loader" ng-show="!debugServices"></div>
|
<div class="cor-loader" ng-show="!debugServices"></div>
|
||||||
|
|
Reference in a new issue