diff options
| author | Paul Buetow <paul@buetow.org> | 2026-02-18 19:39:04 +0200 |
|---|---|---|
| committer | Paul Buetow <pbuetow@mimecast.com> | 2026-02-18 19:39:04 +0200 |
| commit | 1e0b0f9e9573d1c6188fc683591e1f8ae044ca1f (patch) | |
| tree | 023bac27dc261ee546572b6c253e647d6a802d99 /internal/display | |
| parent | 3cc9d42252b7d5f9c24c10ef748cff1d2e1bbd67 (diff) | |
Disk I/O: collect stats on remote, dynamic bar count, reset peak on r
- Add M DISKSTATS block to embedded loadbars-remote.sh so disk I/O is
collected from /proc/diskstats on remote hosts (was only in scripts/ copy).
- Document in countBars that total bars are computed per host (dynamic
device count when disk mode is per-device).
- Extend r hotkey to reset disk auto-scale peak to 1 MB/s floor when disk
bars are on and diskmax is not fixed; update README and help text.
Co-authored-by: Cursor <cursoragent@cursor.com>
Diffstat (limited to 'internal/display')
| -rw-r--r-- | internal/display/display.go | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/internal/display/display.go b/internal/display/display.go index 94b4c76..514a62f 100644 --- a/internal/display/display.go +++ b/internal/display/display.go @@ -231,6 +231,14 @@ func handleToggleKeys(sym sdl.Keycode, cfg *config.Config, state *runState) { } else { fmt.Println("==> Load peak reset ignored (fixed loadmax =", cfg.LoadMax, ")") } + // Reset disk auto-scale peak to the floor when disk bars are on and diskmax is not fixed. + if state.diskMode != constants.DiskModeOff && cfg.DiskMax == 0 { + const diskPeakFloorBps = 1048576.0 // 1 MB/s, same as in updateDiskPeak + state.diskPeak = diskPeakFloorBps + fmt.Println("==> Disk peak reset to auto-scale floor (1 MB/s)") + } else if state.diskMode != constants.DiskModeOff && cfg.DiskMax > 0 { + fmt.Println("==> Disk peak reset ignored (fixed diskmax =", cfg.DiskMax, ")") + } case sdl.K_e: state.extended = !state.extended fmt.Println("==> Toggled extended (peak line):", state.extended) @@ -394,6 +402,10 @@ func drawFrame(renderer *sdl.Renderer, src stats.Source, cfg *config.Config, sta drawOverlay(renderer, snap, cfg, state) } +// countBars returns the total number of bars to display. The total is computed +// dynamically per snapshot: each host contributes its own CPU/mem/net/load bars +// plus its own disk device count (so servers with different numbers of devices +// are all included). func countBars(snap map[string]*stats.HostStats, cpuMode int, showMem, showNet, showLoad bool, diskMode int) int { n := 0 for _, host := range sortedHosts(snap) { @@ -408,6 +420,7 @@ func countBars(snap map[string]*stats.HostStats, cpuMode int, showMem, showNet, if showLoad { n++ } + // Per-host device count: aggregate=1 bar, devices=whole-disk count, off=0 n += len(sortedDiskNames(h.Disk, diskMode)) } } @@ -826,7 +839,7 @@ func drawMemBarSmoothed(renderer *sdl.Renderer, h *stats.HostStats, smoothed *st } func printHotkeys() { - fmt.Println("=> Hotkeys: 1=cores 2/m=mem 3/n=net 4/l=load 5=disk r=reset load peak e=extended g=avg line i=io avg s=separators h=help q=quit w=write config a/y=cpu avg d/c=net avg b/x=disk avg f/v=link scale arrows=resize") + fmt.Println("=> Hotkeys: 1=cores 2/m=mem 3/n=net 4/l=load 5=disk r=reset load/disk peak e=extended g=avg line i=io avg s=separators h=help q=quit w=write config a/y=cpu avg d/c=net avg b/x=disk avg f/v=link scale arrows=resize") } // scaleLinkUp moves cfg.NetLink to the next higher link speed in linkScales. |
