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声明,避免影响其他人构建。