贝利信息

Go模块是否支持离线构建_Go依赖缓存机制解析

日期:2026-01-17 00:00 / 作者:P粉602998670
可以,但需满足依赖已缓存、go.mod/go.sum完整未篡改;首次构建后,不执行go get或修改版本即可离线build;通过go mod verify、go mod download -json等验证缓存完整性。

Go build 能否完全离线运行

可以,但前提是所有依赖模块已缓存在本地 pkg/mod 目录中,且 go.mo

dgo.sum 文件完整、未被篡改。Go 1.13+ 默认启用 GOPROXY=https://proxy.golang.org,direct,首次构建会自动下载并缓存模块;只要不执行 go get 或修改 require 版本,后续 go build 不触发网络请求。

如何确认依赖已全部缓存

检查 $GOPATH/pkg/mod(或 $GOMODCACHE 指向的路径)是否存在对应模块目录,例如 github.com/go-sql-driver/mysql@v1.7.1。更可靠的方式是运行:

go mod verify

若输出 all modules verified,说明 go.sum 中记录的哈希与本地缓存内容一致;若报错 missing zip hashmismatched hash,代表缓存损坏或缺失,此时即使有文件也无法离线构建。

强制离线构建的三种有效方式

Go 没有全局 “offline mode” 开关,但可通过组合环境变量和参数实现确定性离线行为:

最稳妥的离线构建命令是:

GOPROXY=off GOSUMDB=off go build -mod=readonly

CI/CD 中离线构建的关键陷阱

很多 CI 流程误以为 go mod vendor 后就能断网构建,其实不然:

真正可靠的离线交付单元,不是单个二进制,而是包含完整 pkg/mod/cache/download 子树的模块缓存快照——这点常被忽略。