mirror of
https://github.com/csehviktor/status-monitor.git
synced 2026-04-29 00:27:35 +02:00
improve agent + config
This commit is contained in:
+11
-26
@@ -1,4 +1,4 @@
|
||||
use common::metrics::{CPU, Disk, Memory, Metrics, Network, SystemInfo};
|
||||
use common::metrics::{Disk, Memory, Metrics, Network, SystemInfo, CPU};
|
||||
use sysinfo::{Disks, Networks, System};
|
||||
|
||||
pub struct Collector {
|
||||
@@ -19,8 +19,7 @@ impl Collector {
|
||||
pub fn collect_all(&mut self) -> Metrics {
|
||||
let system_info = self.collect_sysinfo();
|
||||
|
||||
self.sys.refresh_cpu_usage();
|
||||
self.sys.refresh_memory();
|
||||
self.sys.refresh_all();
|
||||
self.networks.refresh(true);
|
||||
|
||||
let cpu = self.collect_cpu();
|
||||
@@ -28,27 +27,23 @@ impl Collector {
|
||||
let memory = self.collect_memory();
|
||||
let network = self.collect_network();
|
||||
|
||||
let metrics = Metrics {
|
||||
Metrics {
|
||||
system_info,
|
||||
cpu,
|
||||
disk,
|
||||
memory,
|
||||
network,
|
||||
};
|
||||
|
||||
metrics
|
||||
}
|
||||
}
|
||||
|
||||
fn collect_sysinfo(&self) -> SystemInfo {
|
||||
let system_info = SystemInfo {
|
||||
SystemInfo {
|
||||
uptime: System::uptime(),
|
||||
host: System::host_name(),
|
||||
name: System::name(),
|
||||
kernel: System::kernel_version(),
|
||||
os_version: System::os_version(),
|
||||
};
|
||||
|
||||
system_info
|
||||
}
|
||||
}
|
||||
|
||||
fn collect_cpu(&self) -> CPU {
|
||||
@@ -65,31 +60,21 @@ impl Collector {
|
||||
}
|
||||
|
||||
fn collect_disk(&self) -> Disk {
|
||||
let disk = self
|
||||
.disks
|
||||
.iter()
|
||||
.max_by_key(|disk| disk.total_space())
|
||||
.unwrap();
|
||||
|
||||
let total = disk.total_space();
|
||||
let free = disk.available_space();
|
||||
let disk = self.disks.iter().max_by_key(|disk| disk.total_space()).unwrap();
|
||||
|
||||
Disk {
|
||||
used: total - free,
|
||||
free,
|
||||
total
|
||||
free: disk.available_space(),
|
||||
total: disk.total_space(),
|
||||
}
|
||||
}
|
||||
|
||||
fn collect_memory(&self) -> Memory {
|
||||
let memory_metrics = Memory {
|
||||
Memory {
|
||||
used: self.sys.used_memory(),
|
||||
total: self.sys.total_memory(),
|
||||
swap_used: self.sys.used_swap(),
|
||||
swap_total: self.sys.total_swap(),
|
||||
};
|
||||
|
||||
memory_metrics
|
||||
}
|
||||
}
|
||||
|
||||
fn collect_network(&self) -> Network {
|
||||
|
||||
Reference in New Issue
Block a user