hyperlight_host/metrics/
int_gauge.rsuse prometheus::core::{AtomicI64, GenericGauge};
use prometheus::register_int_gauge_with_registry;
use tracing::{instrument, Span};
use super::{
get_metric_opts, get_metrics_registry, GetHyperlightMetric, HyperlightMetric,
HyperlightMetricOps,
};
use crate::{new_error, HyperlightError, Result};
#[derive(Debug)]
pub struct IntGauge {
gauge: GenericGauge<AtomicI64>,
pub name: &'static str,
}
impl IntGauge {
#[instrument(err(Debug), skip_all, parent = Span::current(), level= "Trace")]
pub fn new(name: &'static str, help: &str) -> Result<Self> {
let registry = get_metrics_registry();
let opts = get_metric_opts(name, help);
let gauge = register_int_gauge_with_registry!(opts, registry)?;
Ok(Self { gauge, name })
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn inc(&self) {
self.gauge.inc();
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn dec(&self) {
self.gauge.dec();
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn set(&self, val: i64) {
self.gauge.set(val);
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn get(&self) -> i64 {
self.gauge.get()
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn add(&self, val: i64) {
self.gauge.add(val);
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn sub(&self, val: i64) {
self.gauge.sub(val)
}
}
impl<S: HyperlightMetricOps> GetHyperlightMetric<IntGauge> for S {
#[instrument(err(Debug), skip_all, parent = Span::current(), level= "Trace")]
fn metric(&self) -> Result<&IntGauge> {
let metric = self.get_metric()?;
<&HyperlightMetric as TryInto<&IntGauge>>::try_into(metric)
}
}
impl<'a> TryFrom<&'a HyperlightMetric> for &'a IntGauge {
type Error = HyperlightError;
#[instrument(err(Debug), skip_all, parent = Span::current(), level= "Trace")]
fn try_from(metric: &'a HyperlightMetric) -> Result<Self> {
match metric {
HyperlightMetric::IntGauge(gauge) => Ok(gauge),
_ => Err(new_error!("metric is not a IntGauge")),
}
}
}
impl From<IntGauge> for HyperlightMetric {
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
fn from(gauge: IntGauge) -> Self {
HyperlightMetric::IntGauge(gauge)
}
}
#[macro_export]
macro_rules! int_gauge_inc {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.inc(),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_gauge_dec {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.dec(),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_gauge_set {
($metric:expr, $val:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.set($val),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_gauge_get {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.get(),
Err(e) => {
log::error!("error getting metric: {}", e);
0
}
}
}};
}
#[macro_export]
macro_rules! int_gauge_add {
($metric:expr, $val:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.add($val),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_gauge_sub {
($metric:expr, $val:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntGauge>::metric($metric) {
Ok(val) => val.sub($val),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}