1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
pub enum Kind {
Overall,
SincePrevious,
}
#[derive(Debug, Clone)]
pub struct IoStats {
pub transactions: u64,
pub reads: u64,
pub cache_reads: u64,
pub writes: u64,
pub bytes_read: u64,
pub cache_read_bytes: u64,
pub bytes_written: u64,
pub started: std::time::Instant,
pub span: std::time::Duration,
}
impl IoStats {
pub fn empty() -> Self {
Self {
transactions: 0,
reads: 0,
cache_reads: 0,
writes: 0,
bytes_read: 0,
cache_read_bytes: 0,
bytes_written: 0,
started: std::time::Instant::now(),
span: std::time::Duration::default(),
}
}
pub fn avg_batch_size(&self) -> f64 {
if self.writes == 0 {
return 0.0
}
self.transactions as f64 / self.writes as f64
}
pub fn reads_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
self.reads as f64 / self.span.as_secs_f64()
}
pub fn byte_reads_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
self.bytes_read as f64 / self.span.as_secs_f64()
}
pub fn writes_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
self.writes as f64 / self.span.as_secs_f64()
}
pub fn byte_writes_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
self.bytes_written as f64 / self.span.as_secs_f64()
}
pub fn ops_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
(self.writes as f64 + self.reads as f64) / self.span.as_secs_f64()
}
pub fn transactions_per_sec(&self) -> f64 {
if self.span.as_secs_f64() == 0.0 {
return 0.0
}
(self.transactions as f64) / self.span.as_secs_f64()
}
pub fn avg_transaction_size(&self) -> f64 {
if self.transactions == 0 {
return 0.0
}
self.bytes_written as f64 / self.transactions as f64
}
pub fn cache_hit_ratio(&self) -> f64 {
if self.reads == 0 {
return 0.0
}
self.cache_reads as f64 / self.reads as f64
}
}