vector/sources/host_metrics/
process.rsuse super::{default_all_processes, example_processes, FilterList, HostMetrics};
use std::ffi::OsStr;
use sysinfo::{ProcessRefreshKind, ProcessesToUpdate, System, UpdateKind};
use vector_lib::configurable::configurable_component;
#[cfg(target_os = "linux")]
use vector_lib::metric_tags;
#[configurable_component]
#[derive(Clone, Debug, Default)]
pub struct ProcessConfig {
#[serde(default = "default_all_processes")]
#[configurable(metadata(docs::examples = "example_processes()"))]
processes: FilterList,
}
const RUNTIME: &str = "process_runtime";
const CPU_USAGE: &str = "process_cpu_usage";
const MEMORY_USAGE: &str = "process_memory_usage";
const MEMORY_VIRTUAL_USAGE: &str = "process_memory_virtual_usage";
impl HostMetrics {
pub async fn process_metrics(&self, output: &mut super::MetricsBuffer) {
let mut sys = System::new();
sys.refresh_processes_specifics(
ProcessesToUpdate::All,
true,
ProcessRefreshKind::new()
.with_memory()
.with_cpu()
.with_cmd(UpdateKind::OnlyIfNotSet),
);
output.name = "process";
let sep = OsStr::new(" ");
for (pid, process) in sys.processes().iter().filter(|&(_, proc)| {
self.config
.process
.processes
.contains_str(proc.name().to_str())
}) {
let tags = || {
metric_tags!(
"pid" => pid.as_u32().to_string(),
"name" => process.name().to_str().unwrap_or("unknown"),
"command" => process.cmd().join(sep).to_str().unwrap_or(""))
};
output.gauge(CPU_USAGE, process.cpu_usage().into(), tags());
output.gauge(MEMORY_USAGE, process.memory() as f64, tags());
output.gauge(
MEMORY_VIRTUAL_USAGE,
process.virtual_memory() as f64,
tags(),
);
output.counter(RUNTIME, process.run_time() as f64, tags());
}
}
}
#[cfg(test)]
mod tests {
use crate::sources::host_metrics::tests::count_tag;
use super::super::{HostMetrics, HostMetricsConfig, MetricsBuffer};
#[tokio::test]
async fn generates_process_metrics() {
let mut buffer = MetricsBuffer::new(None);
HostMetrics::new(HostMetricsConfig::default())
.process_metrics(&mut buffer)
.await;
let metrics = buffer.metrics;
assert!(!metrics.is_empty());
assert!(!metrics
.iter()
.any(|metric| !metric.name().starts_with("process_")));
assert_eq!(count_tag(&metrics, "pid"), metrics.len());
assert_eq!(count_tag(&metrics, "name"), metrics.len());
assert_eq!(count_tag(&metrics, "command"), metrics.len());
}
}