Browse Source

Expose check status and response time to Prometheus

pull/101/head
Matthew Macdonald-Wallace 4 years ago
parent
commit
96242dce0d
  1. 21
      server/model/monitor.js

21
server/model/monitor.js

@ -1,4 +1,4 @@
const Prometheus = require('prom-client');
const dayjs = require("dayjs");
const utc = require('dayjs/plugin/utc')
var timezone = require('dayjs/plugin/timezone')
@ -10,6 +10,16 @@ const {R} = require("redbean-node");
const {BeanModel} = require("redbean-node/dist/bean-model");
const {Notification} = require("../notification")
const monitor_response_time = new Prometheus.Gauge({
name: 'monitor_response_time',
help: 'Monitor Response Time (ms)',
labelNames: ['monitor_name']
});
const monitor_status = new Prometheus.Gauge({
name: 'montor_status',
help: 'Monitor Status (1 = UP, 0= DOWN)',
labelNames: ['monitor_name']
});
/**
* status:
* 0 = DOWN
@ -143,12 +153,21 @@ class Monitor extends BeanModel {
bean.important = false;
}
monitor_status.set({
monitor_name: this.name
}, bean.status)
if (bean.status === 1) {
console.info(`Monitor #${this.id} '${this.name}': Successful Response: ${bean.ping} ms | Interval: ${this.interval} seconds | Type: ${this.type}`)
} else {
console.warn(`Monitor #${this.id} '${this.name}': Failing: ${bean.msg} | Type: ${this.type}`)
}
monitor_response_time.set({
monitor_name: this.name
}, bean.ping)
io.to(this.user_id).emit("heartbeat", bean.toJSON());
await R.store(bean)

Loading…
Cancel
Save