在公司网络 + VSCode Remote SSH 环境下使用 Codex 经验总结

声明 :本文仅记录在企业网络环境下 Codex 认证及 VSCode Remote SSH 配置的技术经验,不涉及任何翻墙方法、代理工具或违反相关法律法规的内容。更多细节和完整文章请参考:Codex认证与配置完整踩坑与解决方案

一、问题现象

在公司内网环境下的服务器上,即使服务器已能访问公网,Codex 仍然无法完成登录认证(浏览器超时、Device Code 报错等),但在个人电脑上却可以正常使用。

二、核心解决思路

不在问题环境中强行登录,而是将认证后的凭证迁移到服务器。

具体步骤:

  1. 在个人电脑上登录 Codex,生成 .codex 认证目录。
  2. .codex 目录打包(排除临时文件夹)并上传到服务器。
  3. 在服务器解压、设置正确权限。
  4. 服务器上的 Codex 即可直接使用,无需再次登录。

三、详细操作

1. 在个人电脑上完成认证

在可正常使用 Codex 的个人电脑上,打开终端执行 codex,按提示登录。登录成功后,用户目录下会生成 .codex 文件夹(Windows 路径为 C:\Users\用户名\.codex)。

2. 打包并传输

打包时排除临时目录,避免上传多余文件:

bash 复制代码
cd ~
tar --exclude=.codex/tmp -czf codex.tar.gz .codex

将打包文件传输到服务器:

bash 复制代码
scp codex.tar.gz 用户名@服务器IP:~/

3. 服务器端解压与权限设置

登录服务器,解压并覆盖原有目录:

bash 复制代码
ssh 用户名@服务器IP
cd ~
rm -rf .codex
tar -xzf codex.tar.gz

设置目录及文件权限:

bash 复制代码
chmod 700 .codex
chmod 600 .codex/auth.json .codex/config.toml

完成后直接运行 codex,即可正常使用。

四、VSCode 远程插件断流问题处理

在 VSCode Remote SSH 环境中,可能会遇到插件报错"stream disconnected before completion",但终端运行 codex 正常。原因是远程插件运行时的网络环境与终端不同,需要单独配置。

解决思路:分别配置本地 VSCode 和远程 VSCode 的网络环境,使插件请求能正常通过。

1. 本地 VSCode 配置

在本地 VSCode 的 settings.json 中配置网络访问参数:

json 复制代码
"http.proxy": "http://127.0.0.1:7890",
"http.proxySupport": "override"

注:端口号仅为示例,请根据实际科学上网的情况填写。

2. 远程 VSCode 配置(仅影响集成终端)

为避免影响服务器上其他用户,建议只在 VSCode 远程设置中为集成终端添加网络环境变量:

  • 打开命令面板(Ctrl+Shift+P),输入 Open Remote Settings (JSON)
  • 添加以下内容:
json 复制代码
"terminal.integrated.env.linux": {
   "HTTP_PROXY": "http://127.0.0.1:7890",
   "HTTPS_PROXY": "http://127.0.0.1:7890"
}

配置完成后,重新加载 VSCode 窗口(Developer: Reload Window),插件与集成终端均可正常工作。

五、最佳实践总结

  • 凭证迁移:不在受限环境处理登录,直接迁移认证目录。
  • 环境隔离:服务器网络配置仅在 VSCode 内部生效,不影响其他用户或系统默认行为。
  • 分域配置:区分本地 VSCode 与远程 VSCode 的设置,确保插件与终端都能正常工作。

更多细节和完整文章请参考本人的cnblog:Codex认证与配置完整踩坑与解决方案

相关推荐
爱就是恒久忍耐13 天前
VSCode里如何比较2个branch
ide·vscode·编辑器
意法半导体STM3213 天前
【官方原创】如何为STM32CubeMX2配置Visual Studio Code配置方案
vscode·stm32·单片机·嵌入式硬件·策略模式·stm32cubemx·嵌入式开发
bloglin9999913 天前
vscode中可视化的合并分支,在“合并编辑器中解析”中“与基线进行比较”是什么意思
ide·vscode·编辑器
天疆说13 天前
在 Ubuntu 的 VSCode 中配置 MATLAB
vscode·ubuntu·matlab
春日见14 天前
vscode的AI编程插件推荐:
大数据·ide·vscode·算法·机器学习·编辑器·ai编程
jieshenai14 天前
VScode sys.path,并使CTRL+左键可访问源码
ide·vscode·编辑器
qq_4480111614 天前
VSCode环境搭建
ide·vscode·编辑器
qq_3384323714 天前
VSCode Remote-SSH 远程 Windows Server 卡死的排查与解决
windows·vscode·ssh
console.log('npc')14 天前
Codex 桌面端接入 Headroom 压缩代理完整教程
前端·vscode
女神下凡15 天前
这是 Cursor(Composer) 的五种核心交互模式
服务器·人工智能·windows·vscode·microsoft