Major refactor, additional comments, performance improvements, idle performance improvements, access token, port specification
Release highlights
Introduced split client/agent architecture with a ratatui-based TUI and a lightweight WebSocket agent.
Added adaptive (idle-aware) sampler: agent samples fast only when clients are connected; sleeps when idle.
Implemented metrics JSON caching for instant ws replies; cold-start does one-off collection.
Port configuration: --port/-p, positional PORT, or SOCKTOP_PORT env (default 3000).
Optional token auth: SOCKTOP_TOKEN on agent, ws://HOST:PORT/ws?token=VALUE in client.
Logging via tracing with RUST_LOG control.
CI workflow (fmt, clippy, build) for Linux and Windows.
Systemd unit example for always-on agent.
TUI features
CPU: overall sparkline + per-core history with trend arrows and color thresholds.
Memory/Swap gauges with humanized labels.
Disks panel with per-device usage and icons.
Network download/upload sparklines (KB/s) with peak tracking.
Top processes table (PID, name, CPU%, mem, mem%).
Header with hostname and CPU temperature indicator.
Agent changes
sysinfo 0.36.1 targeted refresh: refresh_cpu_all, refresh_memory, refresh_processes_specifics(ProcessesToUpdate::All, ProcessRefreshKind::new().with_cpu().with_memory(), true).
WebSocket handler: client counting with wake notifications, cold-start handling, proper Response returns.
Sampler uses MissedTickBehavior::Skip to avoid catch-up bursts.
Docs
README updates: running instructions, port configuration, optional token auth, platform notes, example JSON.
Added socktop-agent.service systemd unit.
Platform notes
Linux (AMD/Intel) supported; tested on AMD, targeting Intel next.
Raspberry Pi supported (availability of temps varies by model).
Windows builds/run; CPU temperature may be unavailable (shows N/A).
Known/next
Roadmap includes configurable refresh interval, TUI filtering/sorting, TLS/WSS, and export to file.
Add Context...
README.md
2025-08-08 19:41:32 +00:00
|
|
|
//! Shared agent state: sysinfo handles and hot JSON cache.
|
|
|
|
|
|
|
|
|
|
use std::sync::atomic::AtomicUsize;
|
2025-08-12 03:47:21 +00:00
|
|
|
use std::sync::Arc;
|
2025-08-12 05:37:46 +00:00
|
|
|
use sysinfo::{Components, Disks, Networks, System};
|
2025-08-09 00:25:15 +00:00
|
|
|
use tokio::sync::{Mutex, Notify, RwLock};
|
Major refactor, additional comments, performance improvements, idle performance improvements, access token, port specification
Release highlights
Introduced split client/agent architecture with a ratatui-based TUI and a lightweight WebSocket agent.
Added adaptive (idle-aware) sampler: agent samples fast only when clients are connected; sleeps when idle.
Implemented metrics JSON caching for instant ws replies; cold-start does one-off collection.
Port configuration: --port/-p, positional PORT, or SOCKTOP_PORT env (default 3000).
Optional token auth: SOCKTOP_TOKEN on agent, ws://HOST:PORT/ws?token=VALUE in client.
Logging via tracing with RUST_LOG control.
CI workflow (fmt, clippy, build) for Linux and Windows.
Systemd unit example for always-on agent.
TUI features
CPU: overall sparkline + per-core history with trend arrows and color thresholds.
Memory/Swap gauges with humanized labels.
Disks panel with per-device usage and icons.
Network download/upload sparklines (KB/s) with peak tracking.
Top processes table (PID, name, CPU%, mem, mem%).
Header with hostname and CPU temperature indicator.
Agent changes
sysinfo 0.36.1 targeted refresh: refresh_cpu_all, refresh_memory, refresh_processes_specifics(ProcessesToUpdate::All, ProcessRefreshKind::new().with_cpu().with_memory(), true).
WebSocket handler: client counting with wake notifications, cold-start handling, proper Response returns.
Sampler uses MissedTickBehavior::Skip to avoid catch-up bursts.
Docs
README updates: running instructions, port configuration, optional token auth, platform notes, example JSON.
Added socktop-agent.service systemd unit.
Platform notes
Linux (AMD/Intel) supported; tested on AMD, targeting Intel next.
Raspberry Pi supported (availability of temps varies by model).
Windows builds/run; CPU temperature may be unavailable (shows N/A).
Known/next
Roadmap includes configurable refresh interval, TUI filtering/sorting, TLS/WSS, and export to file.
Add Context...
README.md
2025-08-08 19:41:32 +00:00
|
|
|
|
|
|
|
|
pub type SharedSystem = Arc<Mutex<System>>;
|
2025-08-12 05:37:46 +00:00
|
|
|
pub type SharedComponents = Arc<Mutex<Components>>;
|
|
|
|
|
pub type SharedDisks = Arc<Mutex<Disks>>;
|
|
|
|
|
pub type SharedNetworks = Arc<Mutex<Networks>>;
|
Major refactor, additional comments, performance improvements, idle performance improvements, access token, port specification
Release highlights
Introduced split client/agent architecture with a ratatui-based TUI and a lightweight WebSocket agent.
Added adaptive (idle-aware) sampler: agent samples fast only when clients are connected; sleeps when idle.
Implemented metrics JSON caching for instant ws replies; cold-start does one-off collection.
Port configuration: --port/-p, positional PORT, or SOCKTOP_PORT env (default 3000).
Optional token auth: SOCKTOP_TOKEN on agent, ws://HOST:PORT/ws?token=VALUE in client.
Logging via tracing with RUST_LOG control.
CI workflow (fmt, clippy, build) for Linux and Windows.
Systemd unit example for always-on agent.
TUI features
CPU: overall sparkline + per-core history with trend arrows and color thresholds.
Memory/Swap gauges with humanized labels.
Disks panel with per-device usage and icons.
Network download/upload sparklines (KB/s) with peak tracking.
Top processes table (PID, name, CPU%, mem, mem%).
Header with hostname and CPU temperature indicator.
Agent changes
sysinfo 0.36.1 targeted refresh: refresh_cpu_all, refresh_memory, refresh_processes_specifics(ProcessesToUpdate::All, ProcessRefreshKind::new().with_cpu().with_memory(), true).
WebSocket handler: client counting with wake notifications, cold-start handling, proper Response returns.
Sampler uses MissedTickBehavior::Skip to avoid catch-up bursts.
Docs
README updates: running instructions, port configuration, optional token auth, platform notes, example JSON.
Added socktop-agent.service systemd unit.
Platform notes
Linux (AMD/Intel) supported; tested on AMD, targeting Intel next.
Raspberry Pi supported (availability of temps varies by model).
Windows builds/run; CPU temperature may be unavailable (shows N/A).
Known/next
Roadmap includes configurable refresh interval, TUI filtering/sorting, TLS/WSS, and export to file.
Add Context...
README.md
2025-08-08 19:41:32 +00:00
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
|
pub struct AppState {
|
|
|
|
|
// Persistent sysinfo handles
|
|
|
|
|
pub sys: SharedSystem,
|
|
|
|
|
|
|
|
|
|
// Last serialized JSON snapshot for fast WS responses
|
|
|
|
|
pub last_json: Arc<RwLock<String>>,
|
|
|
|
|
|
|
|
|
|
// Adaptive sampling controls
|
|
|
|
|
pub client_count: Arc<AtomicUsize>,
|
|
|
|
|
pub wake_sampler: Arc<Notify>,
|
|
|
|
|
pub auth_token: Option<String>,
|
2025-08-12 05:37:46 +00:00
|
|
|
|
|
|
|
|
// Cached containers (enumerated once; refreshed per tick)
|
|
|
|
|
pub components: SharedComponents,
|
|
|
|
|
pub disks: SharedDisks,
|
2025-08-12 05:45:24 +00:00
|
|
|
pub networks: SharedNetworks,
|
2025-08-12 05:37:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl AppState {
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
|
pub fn new() -> Self {
|
|
|
|
|
let sys = System::new(); // targeted refreshes per tick
|
|
|
|
|
let components = Components::new_with_refreshed_list(); // enumerate once
|
|
|
|
|
let disks = Disks::new_with_refreshed_list();
|
|
|
|
|
let networks = Networks::new_with_refreshed_list();
|
|
|
|
|
Self {
|
|
|
|
|
sys: Arc::new(Mutex::new(sys)),
|
|
|
|
|
components: Arc::new(Mutex::new(components)),
|
|
|
|
|
disks: Arc::new(Mutex::new(disks)),
|
|
|
|
|
networks: Arc::new(Mutex::new(networks)),
|
|
|
|
|
last_json: Arc::new(RwLock::new(String::new())),
|
|
|
|
|
client_count: Arc::new(AtomicUsize::new(0)),
|
|
|
|
|
wake_sampler: Arc::new(Notify::new()),
|
2025-08-12 06:27:18 +00:00
|
|
|
auth_token: std::env::var("SOCKTOP_TOKEN")
|
|
|
|
|
.ok()
|
|
|
|
|
.filter(|s| !s.is_empty()),
|
2025-08-12 05:37:46 +00:00
|
|
|
}
|
|
|
|
|
}
|
2025-08-09 00:25:15 +00:00
|
|
|
}
|