2021-11-10 11:40:54 +03:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
|
|
|
Date: Wed, 10 Nov 2021 09:29:47 +0100
|
|
|
|
Subject: [PATCH] arc stat/summary: guard access to l2arc MFU/MRU stats
|
|
|
|
|
|
|
|
commit 085321621e79a75bea41c2b6511da6ebfbf2ba0a added printing MFU
|
|
|
|
and MRU stats for 2.1 user space tools, but those keys are not
|
|
|
|
available in the 2.0 module. That means it may break the arcstat and
|
|
|
|
arc_summary tools after upgrade to 2.1 (user space), before a reboot
|
|
|
|
to the new 2.1 ZFS kernel-module happened, due to python raising a
|
|
|
|
KeyError on the dict access then.
|
|
|
|
|
|
|
|
Move those two keys to a .get accessor with `0` as fallback, as it
|
|
|
|
should be better to show some possible wrong data for new stat-keys
|
|
|
|
than throwing an exception.
|
|
|
|
|
|
|
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
2021-11-11 20:17:25 +03:00
|
|
|
|
|
|
|
also move l2_mfu_asize l2_mru_asize l2_prefetch_asize
|
|
|
|
l2_bufc_data_asize l2_bufc_metadata_asize to .get accessor
|
|
|
|
(these are only present with a cache device in the pool)
|
|
|
|
Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
|
2023-04-20 10:26:09 +03:00
|
|
|
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
|
2021-11-10 11:40:54 +03:00
|
|
|
---
|
2023-10-15 13:08:06 +03:00
|
|
|
cmd/arc_summary | 28 ++++++++++++++--------------
|
|
|
|
cmd/arcstat.in | 14 +++++++-------
|
2021-11-11 20:17:25 +03:00
|
|
|
2 files changed, 21 insertions(+), 21 deletions(-)
|
2021-11-10 11:40:54 +03:00
|
|
|
|
2023-10-15 13:08:06 +03:00
|
|
|
diff --git a/cmd/arc_summary b/cmd/arc_summary
|
|
|
|
index 426e02070..9de198150 100755
|
|
|
|
--- a/cmd/arc_summary
|
|
|
|
+++ b/cmd/arc_summary
|
|
|
|
@@ -655,13 +655,13 @@ def section_arc(kstats_dict):
|
2021-11-10 11:40:54 +03:00
|
|
|
prt_i1('L2 cached evictions:', f_bytes(arc_stats['evict_l2_cached']))
|
|
|
|
prt_i1('L2 eligible evictions:', f_bytes(arc_stats['evict_l2_eligible']))
|
|
|
|
prt_i2('L2 eligible MFU evictions:',
|
|
|
|
- f_perc(arc_stats['evict_l2_eligible_mfu'],
|
|
|
|
+ f_perc(arc_stats.get('evict_l2_eligible_mfu', 0), # 2.0 module compat
|
|
|
|
arc_stats['evict_l2_eligible']),
|
2021-11-10 11:57:42 +03:00
|
|
|
- f_bytes(arc_stats['evict_l2_eligible_mfu']))
|
|
|
|
+ f_bytes(arc_stats.get('evict_l2_eligible_mfu', 0)))
|
2021-11-10 11:40:54 +03:00
|
|
|
prt_i2('L2 eligible MRU evictions:',
|
|
|
|
- f_perc(arc_stats['evict_l2_eligible_mru'],
|
|
|
|
+ f_perc(arc_stats.get('evict_l2_eligible_mru', 0), # 2.0 module compat
|
|
|
|
arc_stats['evict_l2_eligible']),
|
2021-11-10 11:57:42 +03:00
|
|
|
- f_bytes(arc_stats['evict_l2_eligible_mru']))
|
|
|
|
+ f_bytes(arc_stats.get('evict_l2_eligible_mru', 0)))
|
2021-11-10 11:40:54 +03:00
|
|
|
prt_i1('L2 ineligible evictions:',
|
2021-11-10 11:57:42 +03:00
|
|
|
f_bytes(arc_stats['evict_l2_ineligible']))
|
|
|
|
print()
|
2023-10-15 13:08:06 +03:00
|
|
|
@@ -851,20 +851,20 @@ def section_l2arc(kstats_dict):
|
2021-11-11 20:17:25 +03:00
|
|
|
f_perc(arc_stats['l2_hdr_size'], arc_stats['l2_size']),
|
|
|
|
f_bytes(arc_stats['l2_hdr_size']))
|
|
|
|
prt_i2('MFU allocated size:',
|
|
|
|
- f_perc(arc_stats['l2_mfu_asize'], arc_stats['l2_asize']),
|
|
|
|
- f_bytes(arc_stats['l2_mfu_asize']))
|
|
|
|
+ f_perc(arc_stats.get('l2_mfu_asize', 0), arc_stats['l2_asize']),
|
|
|
|
+ f_bytes(arc_stats.get('l2_mfu_asize', 0))) # 2.0 module compat
|
|
|
|
prt_i2('MRU allocated size:',
|
|
|
|
- f_perc(arc_stats['l2_mru_asize'], arc_stats['l2_asize']),
|
|
|
|
- f_bytes(arc_stats['l2_mru_asize']))
|
|
|
|
+ f_perc(arc_stats.get('l2_mru_asize', 0), arc_stats['l2_asize']),
|
|
|
|
+ f_bytes(arc_stats.get('l2_mru_asize', 0))) # 2.0 module compat
|
|
|
|
prt_i2('Prefetch allocated size:',
|
|
|
|
- f_perc(arc_stats['l2_prefetch_asize'], arc_stats['l2_asize']),
|
|
|
|
- f_bytes(arc_stats['l2_prefetch_asize']))
|
|
|
|
+ f_perc(arc_stats.get('l2_prefetch_asize', 0), arc_stats['l2_asize']),
|
|
|
|
+ f_bytes(arc_stats.get('l2_prefetch_asize',0))) # 2.0 module compat
|
|
|
|
prt_i2('Data (buffer content) allocated size:',
|
|
|
|
- f_perc(arc_stats['l2_bufc_data_asize'], arc_stats['l2_asize']),
|
|
|
|
- f_bytes(arc_stats['l2_bufc_data_asize']))
|
|
|
|
+ f_perc(arc_stats.get('l2_bufc_data_asize', 0), arc_stats['l2_asize']),
|
|
|
|
+ f_bytes(arc_stats.get('l2_bufc_data_asize', 0))) # 2.0 module compat
|
|
|
|
prt_i2('Metadata (buffer content) allocated size:',
|
|
|
|
- f_perc(arc_stats['l2_bufc_metadata_asize'], arc_stats['l2_asize']),
|
|
|
|
- f_bytes(arc_stats['l2_bufc_metadata_asize']))
|
|
|
|
+ f_perc(arc_stats.get('l2_bufc_metadata_asize', 0), arc_stats['l2_asize']),
|
|
|
|
+ f_bytes(arc_stats.get('l2_bufc_metadata_asize', 0))) # 2.0 module compat
|
|
|
|
|
|
|
|
print()
|
|
|
|
prt_1('L2ARC breakdown:', f_hits(l2_access_total))
|
2023-10-15 13:08:06 +03:00
|
|
|
diff --git a/cmd/arcstat.in b/cmd/arcstat.in
|
|
|
|
index 8df1c62f7..833348d0e 100755
|
|
|
|
--- a/cmd/arcstat.in
|
|
|
|
+++ b/cmd/arcstat.in
|
|
|
|
@@ -565,8 +565,8 @@ def calculate():
|
2021-11-10 11:40:54 +03:00
|
|
|
v["el2skip"] = d["evict_l2_skip"] // sint
|
|
|
|
v["el2cach"] = d["evict_l2_cached"] // sint
|
|
|
|
v["el2el"] = d["evict_l2_eligible"] // sint
|
|
|
|
- v["el2mfu"] = d["evict_l2_eligible_mfu"] // sint
|
|
|
|
- v["el2mru"] = d["evict_l2_eligible_mru"] // sint
|
|
|
|
+ v["el2mfu"] = d.get("evict_l2_eligible_mfu", 0) // sint
|
|
|
|
+ v["el2mru"] = d.get("evict_l2_eligible_mru", 0) // sint
|
|
|
|
v["el2inel"] = d["evict_l2_ineligible"] // sint
|
|
|
|
v["mtxmis"] = d["mutex_miss"] // sint
|
|
|
|
|
2023-10-15 13:08:06 +03:00
|
|
|
@@ -581,11 +581,11 @@ def calculate():
|
2021-11-11 20:17:25 +03:00
|
|
|
v["l2size"] = cur["l2_size"]
|
|
|
|
v["l2bytes"] = d["l2_read_bytes"] // sint
|
|
|
|
|
|
|
|
- v["l2pref"] = cur["l2_prefetch_asize"]
|
|
|
|
- v["l2mfu"] = cur["l2_mfu_asize"]
|
|
|
|
- v["l2mru"] = cur["l2_mru_asize"]
|
|
|
|
- v["l2data"] = cur["l2_bufc_data_asize"]
|
|
|
|
- v["l2meta"] = cur["l2_bufc_metadata_asize"]
|
|
|
|
+ v["l2pref"] = cur.get("l2_prefetch_asize", 0)
|
|
|
|
+ v["l2mfu"] = cur.get("l2_mfu_asize", 0)
|
|
|
|
+ v["l2mru"] = cur.get("l2_mru_asize", 0)
|
|
|
|
+ v["l2data"] = cur.get("l2_bufc_data_asize", 0)
|
|
|
|
+ v["l2meta"] = cur.get("l2_bufc_metadata_asize", 0)
|
|
|
|
v["l2pref%"] = 100 * v["l2pref"] // v["l2asize"]
|
|
|
|
v["l2mfu%"] = 100 * v["l2mfu"] // v["l2asize"]
|
|
|
|
v["l2mru%"] = 100 * v["l2mru"] // v["l2asize"]
|