Go 模块是 Go 1.11 + 推出的官方依赖管理工具,替代了之前的GOPATH模式,核心作用是:定义项目依赖、管理依赖版本、确保构建一致性
核心文件:go.mod和go.sum
使用module
管理的项目在go mod init后都会生产这两个文件,先介绍go.mod
文件
bash
# 语法:go mod init 模块路径(通常是Git仓库地址,如GitHub、GitLab)
go mod init github.com/your-username/your-project-name
如下图

从上到下分别是:
- 模块路径(唯一标识),相当于这个包的身份证
- go的版本
- 声明直接依赖 和版本
添加更新依赖
当你在代码中引入新的第三方包(如gin
框架),或需要更新依赖版本时,用go get
命令:
bash
# 1. 引入指定版本的依赖(推荐:明确版本,避免兼容性问题)
go get github.com/gin-gonic/gin@v1.9.1
# 2. 引入最新稳定版(不推荐:可能引入不兼容更新)
go get github.com/gin-gonic/gin@latest
# 3. 更新已有依赖到指定版本
go get github.com/gin-gonic/gin@v1.9.2
# 4. 降级依赖版本
go get github.com/gin-gonic/gin@v1.8.1
- 执行
go get
后,Go 会自动:下载依赖到本地缓存($GOPATH/pkg/mod
)、更新go.mod
的require
块、更新go.sum
的校验信息。 - 本地缓存说明:依赖下载后会缓存在
GOPATH/pkg/mod
,多个项目可共享同一版本的依赖,避免重复下载。
清理无用依赖:go mod tidy
当你删除了代码中引用的依赖(如删除了gin
相关代码),go.mod
中可能残留无用的依赖声明,此时用go mod tidy
清理:
go
go mod tidy
- 作用:自动删除
go.mod
中 "代码未引用" 的依赖,同时补充代码中引用但go.mod
未声明的依赖(间接依赖转直接依赖),保持go.mod
简洁。 - 建议:每次提交代码前执行
go mod tidy
,避免无用依赖被提交到仓库。
依赖替换:go mod replace(解决特殊场景)
当你需要用 "本地修改的依赖" 替代 "远程依赖"(如调试第三方包 bug),或 "替换镜像源"(如国内访问 GitHub 慢),用replace
命令:
bash
# 场景1:用本地目录的依赖替换远程依赖(本地路径需是绝对路径或相对路径)
go mod replace github.com/gin-gonic/gin => ../local-gin
# 场景2:用国内镜像替换远程依赖(如用Goproxy.cn的镜像)
go mod replace github.com/gin-gonic/gin => goproxy.cn/github.com/gin-gonic/gin@v1.9.1
- 执行后,
go.mod
会新增replace
块:go
bash
replace github.com/gin-gonic/gin => ../local-gin // 本地替换
- 注意:调试完成后,需删除
replace
声明,避免影响其他人构建。