介绍
Go modules是官方提供的go包管理工具,用于解决go包管理和依赖问题;从1.11开始引入,到现在1.14已经比较完善,1.16已经全面推荐使用,并且默认为开启;Go Modules类似于JS的NPM,Java的maven和gradle。
- GO111MODULE=off: 不使用 modules 功能
- GO111MODULE=on: 使用 modules 功能,不会去 GOPATH 下面查找依赖包
- GO111MODULE=auto: Golang 自己检测是不是使用 modules 功能
- 计划在 Go 1.17 中放弃对 GOPATH将忽略 GO111MODULE,需要关注默认下载目录如何设置,此特性静观1.17版本发布
关于go.mod
module hellogo 1.14require github.com/gogf/gf v1.15.3
配置完编译成功后,生成go.sum依赖分析结果,里面会有当前所有的依赖详细信息;
go modules指令
go get -u (没有参数)下载、更新当前包下 直接和间接的依赖的最新版本,并不会更新整个项目。go get -u ./…下载、更新当前项目根目录下直接或间接的依赖的最新版本,但是会排除测试包的依赖;例如将v1.2.1更新为v2.0.1go get -u=patch ./…下载、更新当前项目根目录下直接或间接的依赖的大版本的最新小版本,例如,将v1.2.1更新为v1.2.5go get -u -t ./… 和go get -u ./…相似,但是会更新测试包的依赖go get -d 只执行下载动作,而不执行安装动作;不再支持go get -m ,使用go get -d替代。
2. go list
go list -m all 列出当前项目build时需要使用直接或间接依赖的版本。 go list -u -m all 不仅会列出当前使用模块的版本,还会列出当前使用模块的最新小版本和最新版本。
3.go build ./… 构建当前项目
4.go test ./… 执行当前项目的测试
5.go mod
go mod tidy 删除不必要的依赖,添加OS, architecture, and build tags组合所需要的依赖。 go mod vendor 可选步骤,用于建立vendor文件夹,用于vendor机制的包管理go mod init 将go项目初始化成module-mode,使用go modules进行依赖管理。go mod verify 校验go.sum记录的依赖信息是否正确
go modules需要注意的地方
- 在项目目录下生成go.mod
- 项目中的包引用使用import “[module名称]/[包所在文件在项目中的相对路径]”
Goland配置
首先我们需要开启go modules功能,然后配置代理;不配置代理会访问国外地址,会很慢;建议使用以下三个地址:
- https://goproxy.io
- https://goproxy.cn
- https://mirrors.aliyun.com/goproxy/
项目结构:
创建go.mod,内容如下
module hellogo 1.14require (github.com/gogf/gf v1.15.3)
代码内容如下:
package mainimport ( “fmt” “github.com/gogf/gf” “github.com/gogf/gf/crypto/gmd5”)func main(){ fmt.Println(“hello world!”) fmt.Println(gf.VERSION) fmt.Println(gmd5.EncryptString(“123456”))}
第一次我们需要下载依赖包,可以选择go.mod文件右键选择Go Mod Tidy
或者点击没下载的包,alt+enter键,选择Sync packages of hello
然后运行程序看到运行结果
hello world!v1.15.3e10adc3949ba59abbe56e057f20f883e Process finished with exit code 0