-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathindex.js
115 lines (92 loc) · 3.91 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
const tx2 = require('tx2')
const SystemInfos = require('./src/SystemInfos.js')
const PM2Infos = require('./src/pm2.js')
class SysMonit {
constructor() {
this.sysinfos = new SystemInfos()
this.report = {}
this.pass = 0
this.pm2infos = new PM2Infos()
this.pm2_report = {}
}
start() {
this.sysinfos.startCollection()
this.report = this.sysinfos.report()
this.pm2infos.startCollection()
this.pm2_report = this.pm2infos.report()
this.bindActions()
setInterval(() => {
if (this.pass++ < 4)
this.bindMetrics()
this.report = this.sysinfos.report()
this.pm2_report = this.pm2infos.report()
this.processContinuousMetrics()
if (process.env.VERBOSE) {
console.log(JSON.stringify(this.report, '', 2))
console.log(JSON.stringify(this.pm2_report, '', 2))
}
}, 1000)
}
bindActions() {
tx2.action('info', (cb) => {
cb(this.sysinfos.report())
})
}
processContinuousMetrics() {
let most_used_disk = this.report.storage.filesystems.reduce((p, v) => {
return (p.use < v.use ? p : v)
})
tx2.metric(`Disk Usage`, '%', () => most_used_disk.use)
tx2.metric(`Disk Size`, 'gb', () => (most_used_disk.size / 1024 / 1024 / 1024).toFixed(2))
let tx5 = 0, rx5 = 0
Object.keys(this.report.network).forEach(iface => {
tx5 += this.report.network[iface].tx_5
rx5 += this.report.network[iface].rx_5
})
tx2.metric(`Total TX`, 'mb/s', () => tx5)
tx2.metric(`Total RX`, 'mb/s', () => rx5)
}
bindMetrics() {
tx2.metric('PM2 CPU Usage', '%', () => this.pm2_report.pm2.cpu)
tx2.metric('PM2 Memory Usage', 'mb', () => this.pm2_report.pm2.mem)
tx2.metric('PM2 Agent CPU Usage', '%', () => this.pm2_report.agent.cpu)
tx2.metric('PM2 Agent Memory Usage', 'mb', () => this.pm2_report.agent.mem)
/**
* From Sysinfo
*/
tx2.metric('CPU Usage', '%', () => this.report.cpu.load)
tx2.metric('CPUs Usage', () => this.report.cpu.loads)
tx2.metric('CPU Temperature', '°C', () => this.report.cpu.temperature)
tx2.metric('RAM Total', 'gb', () => this.report.mem.total)
tx2.metric('RAM Free', 'gb', () => this.report.mem.free)
tx2.metric('RAM Active', 'gb', () => this.report.mem.active)
tx2.metric('RAM Available', 'gb', () => this.report.mem.available)
tx2.metric('RAM Usage', '%', () => this.report.mem.usage)
tx2.metric('FD Opened', () => this.report.fd.opened)
tx2.metric('Disk Writes', 'mb/s', () => this.report.storage.io.read)
tx2.metric('Disk Reads', 'mb/s', () => this.report.storage.io.write)
this.report.storage.filesystems.forEach((fss, i) => {
if (!fss.fs) return
tx2.metric(`fs:use:${fss.fs}`, '%', () => this.report.storage.filesystems[i].use)
tx2.metric(`fs:size:${fss.fs}`, 'gb', () => (this.report.storage.filesystems[i].size / 1024 / 1024 / 1024).toFixed(2))
})
Object.keys(this.report.network).forEach(iface => {
tx2.metric(`net:tx_5:${iface}`, 'mb/s', () => this.report.network[iface].tx_5)
tx2.metric(`net:rx_5:${iface}`, 'mb/s', () => this.report.network[iface].rx_5)
tx2.metric(`net:rx_errors_60:${iface}`, '/min', () => this.report.network[iface].rx_errors_60)
tx2.metric(`net:tx_errors_60:${iface}`, '/min', () => this.report.network[iface].tx_errors_60)
tx2.metric(`net:rx_dropped_60:${iface}`, '/min', () => this.report.network[iface].rx_dropped_60)
tx2.metric(`net:tx_dropped_60:${iface}`, '/min', () => this.report.network[iface].tx_dropped_60)
})
if (this.report.graphics.memTotal) {
tx2.metric('graphics:mem:total', 'mb', () => this.report.graphics.memTotal)
tx2.metric('graphics:mem:used', 'mb', () => this.report.graphics.memUsed)
tx2.metric('graphics:temp', '°C', () => this.report.graphics.temperature)
}
//tx2.transpose('report', () => this.report)
}
}
if (require.main === module) {
let sys = new SysMonit()
sys.start()
}