Go模块代理需配置GOPROXY=https://goproxy.cn,direct才能解决timeout和版本匹配问题,direct确保私有仓库直连;go get不更新go.mod通常因不在模块根目录或GO111MODULE未启用;vendor需用-go mod=vendor显式启用。
直接运行 go get github.com/sirupsen/logrus 报错 timeout 或 no matching versions,大概率是 Go 模块代理没配对。Go 1.13+ 默认启用模块代理,但国内直连 proxy.golang.org 不稳定,必须显式配置可信镜像源。
export GOPROXY=https://goproxy.cn,direct(Linux/macOS)或 set GOPROXY=https://goproxy.cn,direct(Windows CMD)go env -w GOPROXY=https://goproxy.cn,direct(推荐,写入 GOENV 文件)direct 是关键——它表示对私有仓库(如公司内网 Git)跳过代理,否则私有模块拉不到go env GOPROXY,输出应为 https://goproxy.cn,direct
在已有项目里执行 go get 却发现 go.mod 没更新依赖、go.sum 也没变化,说明当前目录不在模块根路径,或未启用模块模式。
go.mod 文件;若无,运行 go mod init example.com/myapp(模块名建议用可解析域名,非实际 URL)GOMODCACHE 可写,且磁盘空间充足(缓存默认在 $GOPATH/pkg/mod)GO111MODULE=off:运行 go env -w GO111MODULE=on 强制开启模块支持go get -d;想同时下载并构建,去掉 -d
项目用了 go mod vendor 生成 vendor/,但执行 go build 仍去远程拉包,

vendor/modules.txt —— 这是因为 Go 默认不自动启用 vendor 模式。
go build -mod=vendor
go mod verify,若提示校验失败,说明 vendor/ 和 go.mod 不一致,需重新 go mod vendor
go list -m all 可查看当前解析出的全部模块版本,对比 vendor/modules.txt 是否一致想把 github.com/spf13/cobra 升到 v1.8.0,运行 go get github.com/spf13/cobra@v1.8.0 后 go.mod 里版本没变,或编译报错类型不兼容——常见于语义化版本写法错误或模块路径变更。
v 前缀:@v1.8.0 ✅,@1.8.0 ❌(后者会被当成分支名)/v2 后缀,例如 github.com/gorilla/mux/v2,不能漏掉 /v2
go mod tidy 清理未引用的依赖,并检查 go.sum 是否新增哈希行go list -u -m all 查看可升级列表,再结合 go doc github.com/xxx/yyy 看 API 变更说明go get github.com/sirupsen/logrus@v1.9.3 go mod tidy go list -m github.com/sirupsen/logrus依赖管理真正的麻烦点不在安装,而在版本漂移和间接依赖冲突。一个
go.mod 里看似干净的 require 行,背后可能藏着十几个间接依赖的版本博弈。每次 go get 后,别急着提交,先 go mod graph | grep xxx 看清它到底引入了哪些隐式版本。