🤖
Sub-Agent Overseer
Monitor sub-agent health and progress via a pull-based bash daemon. Use when spawning sub-agents that need progress tracking, staleness detection, and automa...
安全通过
💬Prompt
技能说明
name: subagent-overseer description: Monitor sub-agent health and progress via a pull-based bash daemon. Use when spawning sub-agents that need progress tracking, staleness detection, and automatic status reporting. Replaces manual heartbeat polling with a deterministic status file the agent reads every 3 minutes. Zero AI tokens for monitoring — pure OS-level process checks and filesystem diffs.
Sub-Agent Overseer
Lightweight pull-based daemon that monitors sub-agent health. Writes a status file every N seconds. The heartbeat handler reads it — no push, no noise.
Architecture
overseer.sh (bash, runs in background)
├── /proc/<pid> → gateway alive? CPU? threads?
├── openclaw sessions list → sub-agent count + ages
├── find -newer marker → filesystem activity
└── writes /tmp/overseer/status.json (atomic mv)
heartbeat (agent, every 3min)
└── reads /tmp/overseer/status.json → summarize or HEARTBEAT_OK
Key principle: The overseer does all data collection. The heartbeat handler does zero tool calls if the status file is fresh and healthy.
Quick Start
1. Start the overseer when spawning sub-agents
setsid scripts/overseer.sh \
--workdir /path/to/repo \
--interval 180 \
--max-stale 4 \
--voice \
&>/dev/null &
2. Heartbeat reads the status file
cat /tmp/overseer/status.json
3. Interpret the status
| Field | Meaning |
|---|---|
subagents.count | Active sub-agent sessions |
subagents.details[].stale | Consecutive cycles with no filesystem changes |
subagents.details[].status | active / idle / warning / stuck |
gateway.health.alive | Is openclaw-gateway running? |
filesystem.changes_since_last | Files modified since last check |
4. Staleness thresholds (at 180s interval)
| stale count | Time | Status | Action |
|---|---|---|---|
| 0-1 | 0-3 min | active/idle | Normal |
| 2-3 | 6-9 min | warning | Voice alert (if --voice) |
| ≥4 | ≥12 min | stuck | Agent should investigate/kill |
Heartbeat Handler Protocol
When HEARTBEAT.md fires:
- Read
/tmp/overseer/status.json— if missing or stale (>10 min), restart overseer - If
subagents.count == 0for 2+ cycles → overseer auto-exits → replyHEARTBEAT_OK - If all agents
active→ brief one-line status →HEARTBEAT_OK - If any
stuck→ report which labels are stuck → consider killing viasubagents kill - Never cache a previous heartbeat response. Always read the status file fresh.
Flags
| Flag | Default | Description |
|---|---|---|
--interval | 180 | Seconds between checks |
--workdir | cwd | Directory to watch for file changes |
--labels | (all) | Comma-separated labels to filter |
--max-stale | 4 | Cycles before marking stuck |
--voice | off | Local TTS alerts via jarvis command |
How It Works (No AI Tokens)
- Gateway health: Reads
/proc/<pid>/statusfor CPU, memory, threads, FD count. Pure kernel data. - Sub-agent list: Single
openclaw sessions listcall per cycle. Parses grep output. - Filesystem diff:
find -newer marker— detects any file writes in the workdir. - Status file: JSON written atomically (write to temp,
mvinto place). Any reader sees a complete file. - Self-exit: If no sub-agents for 2 consecutive cycles, the overseer stops itself.
- Dedup:
flockensures only one overseer instance runs at a time.
Cost
- Overseer: $0.00 (bash + /proc + one CLI call per cycle)
- Voice alerts: $0.00 (local sherpa-onnx via
jarvis) - Heartbeat reads status file: $0.00 (one
catcommand) - Only cost is the heartbeat model itself (qwen3 local = free)
如何使用「Sub-Agent Overseer」?
- 打开小龙虾AI(Web 或 iOS App)
- 点击上方「立即使用」按钮,或在对话框中输入任务描述
- 小龙虾AI 会自动匹配并调用「Sub-Agent Overseer」技能完成任务
- 结果即时呈现,支持继续对话优化