2023-01-02 16:00:42 -05:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
2022-07-01 06:43:25 +08:00
|
|
|
|
2021-10-10 17:20:30 +02:00
|
|
|
use crate::serde::Serialize;
|
|
|
|
use crate::OpId;
|
2023-01-14 20:18:58 -08:00
|
|
|
use std::cell::RefCell;
|
|
|
|
use std::cell::RefMut;
|
2021-10-10 17:20:30 +02:00
|
|
|
|
|
|
|
// TODO(@AaronO): split into AggregateMetrics & PerOpMetrics
|
|
|
|
#[derive(Clone, Default, Debug, Serialize)]
|
|
|
|
#[serde(rename_all = "camelCase")]
|
|
|
|
pub struct OpMetrics {
|
|
|
|
pub ops_dispatched: u64,
|
|
|
|
pub ops_dispatched_sync: u64,
|
|
|
|
pub ops_dispatched_async: u64,
|
2021-11-25 19:49:09 +01:00
|
|
|
// TODO(bartlomieju): this field is never updated
|
2021-10-10 17:20:30 +02:00
|
|
|
pub ops_dispatched_async_unref: u64,
|
|
|
|
pub ops_completed: u64,
|
|
|
|
pub ops_completed_sync: u64,
|
|
|
|
pub ops_completed_async: u64,
|
2021-11-25 19:49:09 +01:00
|
|
|
// TODO(bartlomieju): this field is never updated
|
2021-10-10 17:20:30 +02:00
|
|
|
pub ops_completed_async_unref: u64,
|
|
|
|
pub bytes_sent_control: u64,
|
|
|
|
pub bytes_sent_data: u64,
|
|
|
|
pub bytes_received: u64,
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO(@AaronO): track errors
|
|
|
|
#[derive(Default, Debug)]
|
|
|
|
pub struct OpsTracker {
|
2022-07-01 06:43:25 +08:00
|
|
|
ops: RefCell<Vec<OpMetrics>>,
|
2021-10-10 17:20:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
impl OpsTracker {
|
2022-07-01 06:43:25 +08:00
|
|
|
pub fn new(ops_count: usize) -> Self {
|
|
|
|
Self {
|
|
|
|
ops: RefCell::new(vec![Default::default(); ops_count]),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-10 17:20:30 +02:00
|
|
|
pub fn per_op(&self) -> Vec<OpMetrics> {
|
2022-07-01 06:43:25 +08:00
|
|
|
self.ops.borrow().clone()
|
2021-10-10 17:20:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn aggregate(&self) -> OpMetrics {
|
|
|
|
let mut sum = OpMetrics::default();
|
|
|
|
|
2022-07-01 06:43:25 +08:00
|
|
|
for metrics in self.ops.borrow().iter() {
|
2021-10-10 17:20:30 +02:00
|
|
|
sum.ops_dispatched += metrics.ops_dispatched;
|
|
|
|
sum.ops_dispatched_sync += metrics.ops_dispatched_sync;
|
|
|
|
sum.ops_dispatched_async += metrics.ops_dispatched_async;
|
|
|
|
sum.ops_dispatched_async_unref += metrics.ops_dispatched_async_unref;
|
|
|
|
sum.ops_completed += metrics.ops_completed;
|
|
|
|
sum.ops_completed_sync += metrics.ops_completed_sync;
|
|
|
|
sum.ops_completed_async += metrics.ops_completed_async;
|
|
|
|
sum.ops_completed_async_unref += metrics.ops_completed_async_unref;
|
|
|
|
sum.bytes_sent_control += metrics.bytes_sent_control;
|
|
|
|
sum.bytes_sent_data += metrics.bytes_sent_data;
|
|
|
|
sum.bytes_received += metrics.bytes_received;
|
|
|
|
}
|
|
|
|
|
|
|
|
sum
|
|
|
|
}
|
|
|
|
|
2022-03-08 09:28:20 +01:00
|
|
|
#[inline]
|
2022-07-01 06:43:25 +08:00
|
|
|
fn metrics_mut(&self, id: OpId) -> RefMut<OpMetrics> {
|
2023-04-26 20:02:27 +02:00
|
|
|
RefMut::map(self.ops.borrow_mut(), |ops| &mut ops[id as usize])
|
2021-10-10 17:20:30 +02:00
|
|
|
}
|
|
|
|
|
2022-03-08 09:28:20 +01:00
|
|
|
#[inline]
|
2021-10-24 19:30:55 +02:00
|
|
|
pub fn track_sync(&self, id: OpId) {
|
2022-07-01 06:43:25 +08:00
|
|
|
let mut metrics = self.metrics_mut(id);
|
2021-10-10 17:20:30 +02:00
|
|
|
metrics.ops_dispatched += 1;
|
|
|
|
metrics.ops_completed += 1;
|
|
|
|
metrics.ops_dispatched_sync += 1;
|
|
|
|
metrics.ops_completed_sync += 1;
|
|
|
|
}
|
|
|
|
|
2022-03-08 09:28:20 +01:00
|
|
|
#[inline]
|
2021-10-24 19:30:55 +02:00
|
|
|
pub fn track_async(&self, id: OpId) {
|
2022-07-01 06:43:25 +08:00
|
|
|
let mut metrics = self.metrics_mut(id);
|
2021-10-10 17:20:30 +02:00
|
|
|
metrics.ops_dispatched += 1;
|
|
|
|
metrics.ops_dispatched_async += 1;
|
|
|
|
}
|
|
|
|
|
2022-03-08 09:28:20 +01:00
|
|
|
#[inline]
|
2021-10-24 19:30:55 +02:00
|
|
|
pub fn track_async_completed(&self, id: OpId) {
|
2022-07-01 06:43:25 +08:00
|
|
|
let mut metrics = self.metrics_mut(id);
|
2021-10-10 17:20:30 +02:00
|
|
|
metrics.ops_completed += 1;
|
|
|
|
metrics.ops_completed_async += 1;
|
|
|
|
}
|
|
|
|
}
|