Go 1.11起官方正式支持go mod,vendor是其可选输出而非替代方案;go mod负责依赖声明与版本解析,vendor用于离线构建和依赖锁定,二者协同工作。
Go 1.11 起官方正式支持 go mod,它已成为 Go 项目依赖管理的标准方式;vendor 目录则用于将依赖锁定并打包进项目本地,适合离线构建或严格控制依赖版本的场景。两者不是互斥关系——go mod 是依赖声明与版本解析的核心机制,vendor 是其可选输出结果。
在项目根目录下运行命令即可开启模块模式:
go mod init example.com/myproject —— 初始化 go.mod 文件(模块路径建议用实际域名或唯一标识)go run、go build 或 go test 时,Go 会自动记录新引入的依赖到 go.mod,并下载到本地缓存($GOPATH/pkg/mod)Gopkg.lock(dep 工具)或 vendor/,go mod init 会尝试迁移依赖信息日常开发中高频使用的命令包括:
go mod tidy —— 清理未引用的依赖,添加缺失的依赖,同步 go.mod 和 go.sum
go get -u package@v1.2.3 —— 升级指定依赖到某版本(-u 表示更新次要版本)go mod vendor —— 将当前 go.mod 中所有依赖复制到 vendor/ 目录(不改变 go.mod)go list -m all —— 查看当前模块及所有依赖的版本列表go mod verify —— 校验依赖哈希是否与 go.sum 一致,确保完整性vendor 不是替代 go mod 的方案,而是补充手段:
go mod vendor + go build -mod=vendor 完全离线构建go build -mod=vendor 表示强制只读取 vendor/ 下的代码,忽略 go.mod 中的远程路径和版本声明vendor 不会自动更新,每次依赖变更后需手动运行 go mod vendor 同步vendor/ 提交进 Git,但需在 .gitignore 中排除 vendor/modules.txt(该文件由 Go 自动生成,无需手动维护)实际使用中容易踩坑的地方:
GO111MODULE=on(Go 1.16+ 默认开启),并在非 $GOPATH/src 下开发新项目go.sum 不可随意删除或修改:它是依赖包内容的校验和,删掉会导致 go build 失败或安全警告replace 或 GOPRIVAT
E 环境变量,否则 go get 可能因认证失败而中断/v2,且 go.mod 中模块名也需对应(语义化版本规范要求)