name: rch user-invocable: false skill_api_version: 1 hexagonal_role: supporting metadata: tier: execution description: "Use when offloading slow builds to remote workers or recovering RCH worker, hook, SSH, sync, or disk issues." practices:
- pragmatic-programmer
RCH — Remote Compilation Helper
rch transparently offloads compilation commands to remote workers via a Claude Code PreToolUse hook. The daemon picks the fastest healthy worker, rsync's the workspace, runs the build, syncs artifacts back, and exits with the worker's exit code.
This skill is the operational layer agents use when something about that pipeline isn't working — and the much more common case where it thinks it's working but is silently falling back to local execution. The skill is built around a single principle: self-resolve before asking the human. Every recovery path here is one the agent can run on its own.
Don't re-learn the command surface here. rch --help, rch doctor, and the machine surfaces (--json, --schema, --help-json, --capabilities — see MACHINE_INTROSPECTION.md) self-describe every subcommand, flag, and env var. Env-var knobs and config precedence: CONFIGURATION.md. This skill carries the triage doctrine and recovery playbook routing.
Tested against rch v1.0.18; concepts apply to v1.0.16+.
Read This First
When a build feels slow, run one thing:
RCH_VISIBILITY=verbose <your-command> 2>&1 | grep -E '^\[RCH\]'
The summary line is a contract:
| Pattern | What to do |
|---|---|
[RCH] remote <worker> (...) |
Healthy. Done. |
[RCH] remote <worker> failed [RCH-Exxx] ... |
Real build/env failure. See ERROR_CODES.md. |
[RCH] local (<reason>) |
Fail-open. See FAIL_OPEN.md and look up the reason verbatim. |
no [RCH] line at all |
Hook didn't fire. Run scripts/protocol_test.sh "<your-command>". |
If you can't see why offload isn't happening, prove the path works in isolation before doing anything else:
rch exec -- env CARGO_TARGET_DIR="${TMPDIR:-/tmp}/rch_target_$(basename "$PWD")" cargo check --workspace --all-targets
If that prints [RCH] remote <worker> (...), the offload pipeline is healthy. The problem is upstream of rch exec — usually the hook classifier or the agent's invocation form. If it also fails, follow RECOVERY_PLAYBOOKS.md.
Fast Triage Order
Run in this order and stop at the first failing stage:
- Availability —
rch check,rch status --workers --jobs,rch workers probe --all,rch queue - Config + socket consistency —
rch config show --sources,rch --json config get general.socket_path,rch --json daemon status - Hook integration —
rch hook status,rch agents status,rch hook install(idempotent) - Command classification + path closure —
rch diagnose --dry-run "<your-command>" - Remote compile proof — the
rch execprobe above - If sync fails or storage looks bad, inspect the worker directly:
ssh ubuntu@<host> 'df -h / /tmp && free -h && cat /proc/pressure/memory && cat /proc/pressure/io'
ssh ubuntu@<host> 'du -sh /tmp/rch-* /tmp/rch_target_* 2>/dev/null | sort -h'
Always check both / and /tmp on the worker before deciding what to fix. End-to-end verify: rch self-test --all; comprehensive checks: rch doctor (--fix --dry-run previews auto-fixes).
Quick Fixes
| Symptom | Command |
|---|---|
| Hook not installed | rch hook install && rch hook status |
| Daemon not running | rch daemon start |
| Daemon version drift / stale socket state | rch daemon restart -y (drains gracefully — safe by default) |
| No workers configured | rch workers discover --add --yes && rch workers setup --all |
| Workers unreachable | rch workers probe --all, fix SSH key/host — or SSH_KEY_RECOVERY.md |
| All workers busy + fail-open | Queueing is default-on; bump RCH_DAEMON_WAIT_RESPONSE_TIMEOUT_SECS=120 or raise total_slots |
| Transfer churn under target dirs | Add excludes in ~/.config/rch/config.toml, then rch daemon reload |
| Path dependency missing remotely | PATH_DEPENDENCIES.md (configurable via [path_topology]) |
Sync fails Permission denied in /data/projects/<repo> |
ssh ubuntu@<host> 'sudo chown -R ubuntu:ubuntu /data/projects/<repo> && sudo chmod 775 /data/projects/<repo>' |
| Worker disk pressure (RCH-E210/211/...) | DISK_AND_PRESSURE.md — hand off to the sbh skill |
| Telemetry / SpeedScore broken | TELEMETRY_RECOVERY.md — move db aside, restart |
| Hook says installed but isn't intercepting | scripts/protocol_test.sh "<your-command>" |
| Multiple agents racing on fleet ops | Wrap with scripts/multi_agent_safety.sh <cmd> and use Agent Mail file reservations |
| Need full environment diagnosis | rch doctor --json and rch config doctor |
Debugging fail-opens: RCH_VISIBILITY=verbose shows the summary line; RCH_LOG_LEVEL=debug surfaces which fail-open path was taken. All other env knobs (priority, env allowlist, SSH keepalives, compression, profiles): rch --help + CONFIGURATION.md + SSH_TUNING.md.
Anti-Asking Rules
These are the questions agents historically ask the human that they should just answer themselves. The answer is in this skill or trivially derivable. Do not ask. Do.
- "Can I restart the daemon?" — Yes.
rch daemon restart -ydrains in-flight builds gracefully. It's the documented upgrade path. - "Can I clean up
/tmp/rch_target_*?" — Ifsudo lsof +D <dir>is empty, yes. See DISK_AND_PRESSURE.md. If non-empty, never. - "Should I fix the chown on the worker?" — If the symptom matches the Permission denied recipe, yes. It's documented.
- "Should I disable an unreachable worker and continue?" — Yes.
rch workers disable <id> --reason "..." --drain -y, then proceed with what's healthy. - "Should I reinstall the hook?" — If
rch hook statussays missing, yes.rch hook installis idempotent. - "Should I sync the toolchain to the workers?" — If
RCH-E205or "toolchain missing on X" appears, yes.rch workers sync-toolchain --all. - "The cooldown is blocking my retry — should I delete it?" — No. Wait
auto_start_cooldown_secs. If you really need to bypass, userch daemon startdirectly (it's not gated by the hook autostart cooldown). - "Can I drop the corrupt telemetry db?" — Yes. TELEMETRY_RECOVERY.md. Telemetry is derived data.
- "Should I recover SSH keys from a sibling host?" — If the keys are missing on this host but reachable on another, yes. SSH_KEY_RECOVERY.md Step 3.
When in genuine doubt, capture the escalation packet (Playbook end of RECOVERY_PLAYBOOKS.md) and surface that — not a wall of text — to the human.
Reference Index
Everything below ships in the skill. Read whichever is relevant.
Recognising what's wrong:
- FAIL_OPEN.md — every
[RCH] local (...)reason mapped to a self-fix - ERROR_CODES.md — full RCH-Exxx catalog with skill-doc cross-refs
- TROUBLESHOOTING.md — diagnostic flow + common errors
Solving specific failure classes:
- RECOVERY_PLAYBOOKS.md — symptom → fix in ≤90s, organized as 12 lettered playbooks
- SSH_KEY_RECOVERY.md — when workers.toml references keys this host doesn't have
- PATH_DEPENDENCIES.md — multi-repo workspaces, closure planner,
[path_topology] - DISK_AND_PRESSURE.md — RCH-E210..217 + the
sbhhandoff - TELEMETRY_RECOVERY.md — corrupt
~/.local/share/rch/telemetry/telemetry.db - SELF_HEALING.md — autostart cooldown, daemon supervision,
[self_healing] - SSH_TUNING.md — ControlMaster, keepalives, retry classification
Operating in fleets and swarms:
- MULTI_AGENT_CONTENTION.md — TOCTOU, fleet deploy races, autostart cooldown sharing
- OPERATIONS.md — full runbook + worker fleet lifecycle
- WORKERS.md — worker config, drain/disable/enable, deploy
- CONFIGURATION.md — config precedence, env vars, runtime paths
- HOOKS.md — hook protocol, install, test
- MACHINE_INTROSPECTION.md —
--json,--schema,--help-json,--capabilities
Automation scripts (in scripts/):
auto_recover.sh— heuristic, dry-run-by-default fleet recoveryworker_disk_triage.sh— read-only mount-aware disk report per workerprotocol_test.sh— directly probe the hook protocol with synthetic inputmulti_agent_safety.sh— flock wrapper for fleet/setup operationsmine_rch_history.sh— find prior agent sessions that hit a given failurediagnose-rch.sh— comprehensive end-to-end diagnostic (the original)
Templates and project docs:
assets/workers-template.toml- Source: https://github.com/Dicklesworthstone/remote_compilation_helper
Adjacent Skills
sbh— disk-pressure defense for AI coding workloads. Use whenRCH-E210/211/215/216fires.agent-mail— file reservations and messaging between agents. Use beforerch fleet deployor any worker config edit in a swarm.ntm/vibing-with-ntm— multi-agent tmux orchestration; common parent context for agents that hit rch failures.cass— search prior agent sessions; the skill shipsscripts/mine_rch_history.shas a fallback when cass index has dead pointers.
Reading Output: TUI vs Hook
rch itself, when invoked with no subcommand, runs in PreToolUse hook mode (reads JSON from stdin, writes JSON to stdout). Don't run bare rch from a terminal expecting help — use rch --help. Bare TUIs are at rch dashboard (terminal) and rch web (browser); both block your session.