2021-03-26 13:28:03 -05:00
|
|
|
import datetime
|
|
|
|
from django.conf import settings
|
|
|
|
from django.views import View
|
2021-04-27 07:56:02 -05:00
|
|
|
from django.shortcuts import render
|
2021-03-26 13:28:03 -05:00
|
|
|
|
|
|
|
class AppServers(View):
|
|
|
|
|
|
|
|
def get(self, request):
|
2021-04-27 07:56:02 -05:00
|
|
|
data = dict((("%s" % s['_id'].replace('-', ''), s['feeds']) for s in self.stats))
|
2021-03-29 13:28:47 -05:00
|
|
|
if self.total:
|
2021-04-27 07:56:02 -05:00
|
|
|
data['total'] = self.total[0]['feeds']
|
2021-04-30 13:48:48 -05:00
|
|
|
chart_name = "app_servers"
|
2021-05-03 07:56:47 -05:00
|
|
|
chart_type = "counter"
|
2021-04-30 13:48:48 -05:00
|
|
|
context = {
|
|
|
|
"data": data,
|
|
|
|
"chart_name": chart_name,
|
|
|
|
"chart_type": chart_type,
|
2021-05-03 07:56:47 -05:00
|
|
|
}
|
|
|
|
return render(request, 'monitor/prometheus_data.html', context, content_type="text/plain")
|
2021-04-27 07:56:02 -05:00
|
|
|
|
2021-03-26 13:28:03 -05:00
|
|
|
@property
|
|
|
|
def stats(self):
|
|
|
|
stats = settings.MONGOANALYTICSDB.nbanalytics.page_loads.aggregate([{
|
|
|
|
"$match": {
|
|
|
|
"date": {
|
|
|
|
"$gte": datetime.datetime.now() - datetime.timedelta(minutes=5),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}, {
|
|
|
|
"$group": {
|
|
|
|
"_id" : "$server",
|
|
|
|
"feeds" : {"$sum": 1},
|
|
|
|
},
|
|
|
|
}])
|
|
|
|
|
|
|
|
return list(stats)
|
|
|
|
|
|
|
|
@property
|
2021-03-29 13:28:47 -05:00
|
|
|
def total(self):
|
2021-03-26 13:28:03 -05:00
|
|
|
stats = settings.MONGOANALYTICSDB.nbanalytics.page_loads.aggregate([{
|
|
|
|
"$match": {
|
|
|
|
"date": {
|
|
|
|
"$gt": datetime.datetime.now() - datetime.timedelta(minutes=5),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}, {
|
|
|
|
"$group": {
|
|
|
|
"_id" : 1,
|
|
|
|
"feeds" : {"$sum": 1},
|
|
|
|
},
|
|
|
|
}])
|
|
|
|
|
|
|
|
return list(stats)
|