贝利信息

如何配置Golang模块下载代理_Golang GOPROXY设置说明

日期:2026-01-15 00:00 / 作者:P粉602998670
必须配置 GOPROXY,因 Go 1.13+ 默认启用模块且官方代理 proxy.golang.org 国内不可达,直连源站常被拦截;正确配置应为 https://goproxy.cn,direct,推荐用 go env -w 全局设置并配合 GOPRIVATE 处理私有仓库。

国内用 go getgo mod tidy 下载依赖失败、卡在 fetching dependencies,基本就是 GOPROXY 没配对——不是没设,而是设错了顺序、漏了回退机制,或混淆了生效范围。

为什么必须配 GOPROXY

Go 1.13+ 默认启用模块(GO111MODULE=on),所有依赖都走模块协议下载。官方默认代理是 https://proxy.golang.org,但该域名在国内多数网络环境下无法解析或连接超时。不配代理时,Go 会尝试直连 GitHub、GitLab 等源站,而这些请求常被限速、重置或拦截,导致模块拉取失败或极慢。

三种配置方式,优先级和坑点全说清

配置方式按作用范围从小到大排列,但**推荐只用全局方式**,避免终端间行为不一致:

验证是否真正生效?别只看 go env GOPROXY

go env GOPROXY 显示正确 ≠ 实际能用。常见假成功现象:

VS Code 里还单独配 go.toolsEnvVars?没必要

很多人在 .vscode/settings.json 里写:

"go.toolsEnvVars": { "GOPROXY": "https://goproxy.cn" }
这是冗余操作。只要全局执行过 go env -w GOPROXY=...,VS Code 启动的 goplsgo 命令都会读取该值。重复配置反而容易冲突(比如 shell 终端用 goproxy.cn,direct,VS Code 里只写了 goproxy.cn,私有模块就挂了)。

真正要留意的是:VS Code 的集成终端启动时,可能不会自动加载你改过的 ~/.zshrc,所以务必用 go env -w 全局配置,而不是依赖 shell 初始化。