hyperlight_host/metrics/
int_counter.rsuse prometheus::core::{AtomicU64, GenericCounter};
use prometheus::register_int_counter_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 IntCounter {
counter: GenericCounter<AtomicU64>,
pub name: &'static str,
}
impl IntCounter {
#[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 counter = register_int_counter_with_registry!(opts, registry)?;
Ok(Self { counter, name })
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn inc(&self) {
self.counter.inc();
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn inc_by(&self, val: u64) {
self.counter.inc_by(val);
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn get(&self) -> u64 {
self.counter.get()
}
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
pub fn reset(&self) {
self.counter.reset();
}
}
impl<S: HyperlightMetricOps> GetHyperlightMetric<IntCounter> for S {
#[instrument(err(Debug), skip_all, parent = Span::current(), level= "Trace")]
fn metric(&self) -> Result<&IntCounter> {
let metric = self.get_metric()?;
<&HyperlightMetric as TryInto<&IntCounter>>::try_into(metric)
}
}
impl<'a> TryFrom<&'a HyperlightMetric> for &'a IntCounter {
type Error = HyperlightError;
#[instrument(err(Debug), skip_all, parent = Span::current(), level= "Trace")]
fn try_from(metric: &'a HyperlightMetric) -> Result<Self> {
match metric {
HyperlightMetric::IntCounter(counter) => Ok(counter),
_ => Err(new_error!("metric is not a IntCounter")),
}
}
}
impl From<IntCounter> for HyperlightMetric {
#[instrument(skip_all, parent = Span::current(), level= "Trace")]
fn from(counter: IntCounter) -> Self {
HyperlightMetric::IntCounter(counter)
}
}
#[macro_export]
macro_rules! int_counter_inc {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntCounter>::metric($metric) {
Ok(val) => val.inc(),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_counter_inc_by {
($metric:expr, $val:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntCounter>::metric($metric) {
Ok(val) => val.inc_by($val),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}
#[macro_export]
macro_rules! int_counter_get {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntCounter>::metric($metric) {
Ok(val) => val.get(),
Err(e) => {
log::error!("error getting metric: {}", e);
0
}
}
}};
}
#[macro_export]
macro_rules! int_counter_reset {
($metric:expr) => {{
match $crate::metrics::GetHyperlightMetric::<$crate::metrics::IntCounter>::metric($metric) {
Ok(val) => val.reset(),
Err(e) => log::error!("error getting metric: {}", e),
};
}};
}