tmux-autopilot

SKILL.md

tmux-autopilot Skill

让 AI 像熟练运维一样操作 tmux:读取终端输出、发送按键、批量巡检、协作/救援其他终端,默认兼容 assets/repo/.tmux(gpakosz/oh-my-tmux)。

When to Use This Skill

触发条件(满足其一即可):

  • 需要远程读取/复制某个 tmux pane 的最新输出(日志、提示、错误)。
  • 需要向指定 pane 发送按键/命令(确认 yEnterCtrl+C、广播同一窗口)。
  • 需要批量巡检/接管多 AI 终端(蜂群协作、自动救援卡死任务)。
  • 需要快速回忆 oh-my-tmux 快捷键、前缀或同步面板操作。
  • 需要在当前仓库复用 assets/repo/.tmux 配置并避免修改主配置。

Not For / Boundaries

  • 不用于执行非 tmux 环境(目标不存在时先创建 session/window/pane)。
  • 不直接编辑 ~/.tmux.conf / .tmux.conf(遵循 oh-my-tmux:修改请放到 .tmux.conf.local)。
  • 不盲发破坏性按键:kill-serverrm -rf 等必须先 capture-pane 确认目标上下文。
  • 如果 tmux 版本 < 2.6,需先升级再使用本技能的命令组合。

Quick Reference

常用模式(≤20 条,直接复制即用)

查看快捷键帮助(oh-my-tmux 双前缀:主 C-a,备用 C-b,前缀后按 ?

[按] <prefix> ?

枚举拓扑(session/window/pane)

tmux list-sessions
tmux list-windows -a -F '#S:#I:#W#F'
tmux list-panes   -a -F '#S:#I.#P #{pane_current_command} #{pane_title}'

读取指定 pane 最近 120 行

tmux capture-pane -t <session>:<window>.<pane> -p -S -120

向指定 pane 发送确认键

tmux send-keys -t <session>:<window>.<pane> "y" Enter

安全中断挂住任务

tmux send-keys -t <session>:<window>.<pane> C-c

开启/关闭窗口内广播(同步全部 pane)

tmux set-window-option synchronize-panes on
tmux set-window-option synchronize-panes off

一次扫描全部窗口并截取最近输出(蜂群巡检骨架)

for w in $(tmux list-windows -a -F '#S:#I'); do
  tmux capture-pane -t "$w" -p -S -80 | sed "s/^/[$w] /";
done

远程救援:发现等待输入即发送 y

target="0:3.0"  # 示例
tmux capture-pane -t "$target" -p -S -50 | grep -qi "(y/n)" && \
  tmux send-keys -t "$target" "y" Enter

新建 AI 蜂群工作台(1 指挥 + 3 工人)

tmux new-session -d -s ai-hub -n commander 'bash'
tmux new-window  -t ai-hub -n worker1 'kiro-cli chat'
tmux new-window  -t ai-hub -n worker2 'kiro-cli chat'
tmux new-window  -t ai-hub -n worker3 'kiro-cli chat'
tmux attach -t ai-hub

启用 oh-my-tmux 配置(仓库内版本)

ln -sfn /home/lenovo/zip/vibe-coding-cn/assets/repo/.tmux/.tmux.conf ~/.tmux.conf
cp -n /home/lenovo/zip/vibe-coding-cn/assets/repo/.tmux/.tmux.conf.local ~/.tmux.conf.local

记录 pane 输出到文件

tmux pipe-pane -t <session>:<window>.<pane> -o 'cat >> /tmp/tmux-<session>-<window>-<pane>.log'

Rules & Constraints

  • MUST:在发送按键前用 capture-pane 复核目标上下文;按键操作必须带 <session>:<window>.<pane> 绝对定位。
  • MUST:遵循 oh-my-tmux 约定,不修改主配置文件;自定义写入 ~/.tmux.conf.local
  • MUST:批量操作前先 list-windows/list-panes 建立白名单,避免误控用户窗口。
  • SHOULD:救援/确认前先 grep 关键词(如 (y/n)password),只对匹配目标发送。
  • SHOULD:发送完整命令行时避免先发 Escape;先 C-c 中断、C-u 清行,再用 send-keys -l 逐字发送完整命令。
  • SHOULD:pane 处在 Codex UI 时,先发送 /exit 回到 shell 再执行命令。
  • SHOULD:长任务开启 pipe-pane 记录审计;广播完成后立即 synchronize-panes off
  • NEVER:在未知 pane 发送破坏性命令;NEVER 在 root 会话不经确认发送 Ctrl+C/Ctrl+D

Examples

Example 1:自动给卡住的安装脚本回车确认

  • 输入:安装脚本停在 Proceed? (y/n),位置在 0:3.0
  • 步骤:
    1. tmux capture-pane -t 0:3.0 -p -S -50 | grep -qi "(y/n)" 确认等待输入。
    2. tmux send-keys -t 0:3.0 "y" Enter 发送确认。
  • 验收:脚本继续运行,无额外多余输入。

Example 2:蜂群巡检 + 自动救援

  • 输入:4 个 AI 终端分布在 session ai-hub 的多个窗口。
  • 步骤:
    1. 运行 Quick Reference 巡检循环收集最近 80 行并观察状态。
    2. 对匹配 "(y/n)" 的 pane 触发「远程救援」片段自动发 y
    3. 对输出包含 TracebackERROR 的 pane,先 capture-pane 记录再人工介入。
  • 验收:等待确认的终端恢复,未误伤正常任务;巡检日志保存在本地。

Example 3:快速搭建 oh-my-tmux AI 工作台

  • 输入:需要 1 个指挥 + 3 个 worker,并使用仓库内 oh-my-tmux 配置。
  • 步骤:
    1. 运行「启用 oh-my-tmux 配置」片段完成软链和本地副本(若已存在跳过)。
    2. 运行「新建 AI 蜂群工作台」片段创建 session 并 attach。
    3. 在 commander pane 使用「枚举拓扑」确认 worker 窗口存在。
  • 验收:前缀键为 C-a,状态栏正常;4 个窗口可互相捕获/发送按键。

FAQ

  • Q: 为什么按 C-b 无反应?
    • A: oh-my-tmux 默认主前缀是 C-aC-b 仅作备用;确保无其他程序占用 C-a
  • Q: 如何只广播当前窗口而不影响其他窗口?
    • A: 只对当前窗口执行 set-window-option synchronize-panes on,使用完立即关闭。
  • Q: 远程发送命令前如何确认当前工作目录?
    • A: tmux display-message -pt <target> '#{pane_current_path}',必要时先 send-keys 'cd /path' Enter

Troubleshooting

  • no such session/window/pane → 检查目标名称,先 list-sessions/list-windows 校验再重试。
  • 前缀键冲突 → 查看 ~/.tmux.conf.local 是否改写前缀;可在其中设置 set -g prefix C-b #!important
  • 状态栏样式错乱/重复 → 按 README 建议用 tmux -f /dev/null -L test 排查;多半是终端宽字符/字体导致。
  • 发送命令没效果 → 目标 pane 可能在 copy-mode;优先用 tmux display-message -pt <target> '#{pane_in_mode}' 判断,再用 tmux send-keys -t <target> -X cancel 退出;避免用 Escape(会触发 Meta 前缀,可能吞掉首字符)。

References

  • references/index.md: 导航与文件速览
  • references/getting_started.md: 术语、oh-my-tmux 最小接入步骤
  • references/api.md: tmux/oh-my-tmux 常用命令、选项与 gpakosz 特色键位
  • references/examples.md: 蜂群协议脚本与长示例
  • references/troubleshooting.md: 典型故障到修复路径

Maintenance

  • Sources: assets/repo/.tmux/README.md、蜂群实战提示词、Skill Seeker 生成的抓取材料(如需扩展自动化)。
  • Last updated: 2026-01-17
  • Known limits: 未涵盖 tmux 插件管理(tpm)及多用户共享权限配置;需时再补充。

Quality Gate

发布前自检(配合 skills-skills 校验脚本):

  1. description 已含“capture-pane/send-keys/蜂群”等触发关键词。
  2. 「When to Use」「Not For」已覆盖边界;前缀/版本要求清晰。
  3. Quick Reference ≤ 20 条且均可直接执行;无长篇解释。
  4. ≥3 个端到端示例,含输入/步骤/验收。
  5. 长文档放在 references/ 并可导航;无文档堆砌。
  6. 不确定项给出验证路径;禁止虚构 tmux 行为。
  7. 运行 assets/skills/skills-skills/scripts/validate-skill.sh assets/skills/tmux-autopilot 通过。
Weekly Installs
14
GitHub Stars
9.3K
First Seen
Feb 19, 2026
Installed on
opencode14
mcpjam13
claude-code13
junie13
windsurf13
zencoder13