tmux-autopilot Skill
让 AI 像熟练运维一样操作 tmux:读取终端输出、发送按键、批量巡检、协作/救援其他终端,默认兼容 assets/repo/.tmux (gpakosz/oh-my-tmux)。
When to Use This Skill
触发条件(满足其一即可):
-
需要远程读取/复制某个 tmux pane 的最新输出(日志、提示、错误)。
-
需要向指定 pane 发送按键/命令(确认 y 、Enter 、Ctrl+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-server 、rm -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 。
-
步骤:
-
tmux capture-pane -t 0:3.0 -p -S -50 | grep -qi "(y/n)" 确认等待输入。
-
tmux send-keys -t 0:3.0 "y" Enter 发送确认。
-
验收:脚本继续运行,无额外多余输入。
Example 2:蜂群巡检 + 自动救援
-
输入:4 个 AI 终端分布在 session ai-hub 的多个窗口。
-
步骤:
-
运行 Quick Reference 巡检循环收集最近 80 行并观察状态。
-
对匹配 "(y/n)" 的 pane 触发「远程救援」片段自动发 y 。
-
对输出包含 Traceback 或 ERROR 的 pane,先 capture-pane 记录再人工介入。
-
验收:等待确认的终端恢复,未误伤正常任务;巡检日志保存在本地。
Example 3:快速搭建 oh-my-tmux AI 工作台
-
输入:需要 1 个指挥 + 3 个 worker,并使用仓库内 oh-my-tmux 配置。
-
步骤:
-
运行「启用 oh-my-tmux 配置」片段完成软链和本地副本(若已存在跳过)。
-
运行「新建 AI 蜂群工作台」片段创建 session 并 attach。
-
在 commander pane 使用「枚举拓扑」确认 worker 窗口存在。
-
验收:前缀键为 C-a ,状态栏正常;4 个窗口可互相捕获/发送按键。
FAQ
-
Q: 为什么按 C-b 无反应?
-
A: oh-my-tmux 默认主前缀是 C-a ,C-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 校验脚本):
-
description 已含“capture-pane/send-keys/蜂群”等触发关键词。
-
「When to Use」「Not For」已覆盖边界;前缀/版本要求清晰。
-
Quick Reference ≤ 20 条且均可直接执行;无长篇解释。
-
≥3 个端到端示例,含输入/步骤/验收。
-
长文档放在 references/ 并可导航;无文档堆砌。
-
不确定项给出验证路径;禁止虚构 tmux 行为。
-
运行 assets/skills/skills-skills/scripts/validate-skill.sh assets/skills/tmux-autopilot 通过。