mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-07-03 20:07:09 +02:00
Logging the memory usage over time
This commit is contained in:
parent
7e47cea0c4
commit
771861599b
8 changed files with 222 additions and 44 deletions
|
@ -1,4 +1,5 @@
|
|||
use std::borrow::Cow;
|
||||
use std::ops::Sub;
|
||||
|
||||
use serde::{Deserialize, Serialize};
|
||||
use tracing::span::Id as TracingId;
|
||||
|
@ -64,12 +65,14 @@ pub struct NewThread {
|
|||
pub struct SpanEnter {
|
||||
pub id: SpanId,
|
||||
pub time: std::time::Duration,
|
||||
pub memory: Option<MemoryStats>,
|
||||
}
|
||||
|
||||
#[derive(Clone, Copy, Debug, Serialize, Deserialize)]
|
||||
pub struct SpanExit {
|
||||
pub id: SpanId,
|
||||
pub time: std::time::Duration,
|
||||
pub memory: Option<MemoryStats>,
|
||||
}
|
||||
|
||||
#[derive(Clone, Copy, Debug, Serialize, Deserialize)]
|
||||
|
@ -86,6 +89,55 @@ pub struct SpanClose {
|
|||
pub time: std::time::Duration,
|
||||
}
|
||||
|
||||
/// A struct with a lot of memory allocation stats akin
|
||||
/// to the `stats_alloc::Stats` one but implements the
|
||||
/// `Serialize/Deserialize` serde traits.
|
||||
#[derive(Debug, Default, Clone, Copy, Serialize, Deserialize)]
|
||||
pub struct MemoryStats {
|
||||
pub allocations: usize,
|
||||
pub deallocations: usize,
|
||||
pub reallocations: usize,
|
||||
pub bytes_allocated: usize,
|
||||
pub bytes_deallocated: usize,
|
||||
pub bytes_reallocated: isize,
|
||||
}
|
||||
|
||||
impl From<stats_alloc::Stats> for MemoryStats {
|
||||
fn from(stats: stats_alloc::Stats) -> Self {
|
||||
let stats_alloc::Stats {
|
||||
allocations,
|
||||
deallocations,
|
||||
reallocations,
|
||||
bytes_allocated,
|
||||
bytes_deallocated,
|
||||
bytes_reallocated,
|
||||
} = stats;
|
||||
MemoryStats {
|
||||
allocations,
|
||||
deallocations,
|
||||
reallocations,
|
||||
bytes_allocated,
|
||||
bytes_deallocated,
|
||||
bytes_reallocated,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Sub for MemoryStats {
|
||||
type Output = Self;
|
||||
|
||||
fn sub(self, other: Self) -> Self::Output {
|
||||
Self {
|
||||
allocations: self.allocations - other.allocations,
|
||||
deallocations: self.deallocations - other.deallocations,
|
||||
reallocations: self.reallocations - other.reallocations,
|
||||
bytes_allocated: self.bytes_allocated - other.bytes_allocated,
|
||||
bytes_deallocated: self.bytes_deallocated - other.bytes_deallocated,
|
||||
bytes_reallocated: self.bytes_reallocated - other.bytes_reallocated,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Copy, Serialize, Deserialize, PartialEq, Eq, Hash)]
|
||||
pub struct ResourceId(pub(crate) usize);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue