Mac终端的tmux会话使用Codex 时Ctrl+V 可能触发异常并导致会话假死问题以及解决方法

现象

Mac 终端 的 tmux会话 使用 Codex CLI 场景里,复制 DataGrip 的 SQL 后按 Ctrl+V,Codex 可能无反应,并出现类似报错:

Failed to paste image: clipboard unavailable:

X11 server connection timed out because it was unreachable

随后 EnterCtrl+C 也可能失效,表现为当前会话像"卡住"了一样。

同样内容如果使用 Command+V,则可以正常粘贴。

原因分析

这次问题的重点不在于 Ctrl+VCommand+V 的常规区别,而在于:

在 Mac → tmux → Codex TUI 这条链路里,Ctrl+V 可能触发 Codex 的异常剪贴板处理逻辑。

虽然复制的是 DataGrip 里的 SQL,并不是图片,但图形界面应用复制到系统剪贴板时,往往不只有纯文本,还可能带有富文本、HTML 或其他剪贴板格式。

Codex 在 tmux/终端环境下,可能没有把这次输入简单当作"文本粘贴",而是误走到了附件或图片相关的 clipboard 检测逻辑,于是报出了 Failed to paste image 一类错误。

一旦这条处理链出错,Codex 当前 TUI 会话的输入状态就可能异常,进一步表现为:

  • Ctrl+V 后没有正常输入
  • Enter 失效
  • Ctrl+C 也没有正常中断
  • 整个会话看起来像假死

本质结论

这不是 tmux 本身故障,也不是真的在粘贴图片。

更准确地说,这是:Codex 在 Mac 的 tmux 场景下,对 Ctrl+V 触发的剪贴板内容发生了异常处理或误判,最终导致当前会话输入状态异常,表现为假死。

处理方式

最直接的规避办法

在这个场景里,粘贴 SQL 或其他文本时:

  • 优先使用 Command+V或右键粘贴
  • 不要使用 Ctrl+V

更稳的使用建议

如果复制来源是 DataGrip、浏览器、飞书、Notion 之类 GUI 应用,为了减少异常剪贴板格式带来的影响,可以这样做:

  1. 先粘贴到纯文本编辑器
  2. 再重新复制纯文本
  3. 使用 Command+V 粘贴到 Codex

如果是大段 SQL、脚本或日志,更稳的方式是:

  • 先保存成文件
  • 再让 Codex 读取文件内容

如果已经卡住了

方法 1:直接杀掉当前 tmux pane

复制代码
Ctrl+b x

方法 2:从别的终端定位并杀掉 pane

复制代码
tmux list-panes -a -F '#S:#I.#P #{pane_current_command} #{pane_pid}'
tmux kill-pane -t 会话名:窗口.面板

例如:tmux kill-pane -t test-session:0.0

方法 3:直接杀掉 codex 进程

复制代码
ps -ef | grep codex
kill -9 <pid>
相关推荐
被AI抢饭碗的人2 小时前
Linux:UDP与TCP
linux·tcp/ip·udp
EnCi Zheng2 小时前
L1D-Linux系统Node.js部署Claude Code完全指南 [特殊字符]
linux·运维·node.js
qq_172805592 小时前
wsl ubuntu层开放22端口,主机windows层开放2222端口转发
linux·windows·ubuntu·wsl
Elastic 中国社区官方博客2 小时前
Serverless 中用于负载均衡的 Elasticsearch 副本
大数据·运维·人工智能·elasticsearch·搜索引擎·云原生·serverless
新时代牛马2 小时前
Windows SSH 免密码登录 Ubuntu
运维·ubuntu·ssh
李少兄2 小时前
企业级数据库自动化备份
运维·数据库·mysql·自动化
yy_xzz2 小时前
【Linux开发】 01 Linux TCP 网络编程——普通服务器
linux·网络·tcp/ip
sugar15692 小时前
Trae ied为项目完善Docker Compose本地开发运行测试
运维·docker·容器
Trouvaille ~2 小时前
【项目篇】从零手写高并发服务器(九):HTTP协议支持——从TCP到应用层
linux·服务器·c++·tcp/ip·http·高并发·应用层