在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
参考链接:https://blog.csdn.net/weixin_39003229/article/details/97638573 什么是go.mod?Go.mod是Golang1.11版本新引入的官方包管理工具用于解决之前没有地方记录依赖包具体版本的问题,方便依赖包的管理。 Go.mod其实就是一个Modules,关于Modules的官方定义为:
如何使用go.mod? 2 设置GO111MODULE
环境配置使用之前我们要进行前期的准备,设置go的环境配置
go.mod如何在项目中使用?1.首先我们要在GOPATH/src 目录之外新建工程,或将老工程copy到GOPATH/src 目录之外。 PS:go.mod文件一旦创建后,它的内容将会被go toolchain全面掌控。go toolchain会在各类命令执行时,比如go get、go build、go mod等修改和维护go.mod文件。 go.mod 提供了module, require、replace和exclude四个命令1 module语句指定包的名字(路径)
2.在当前目录下,命令行运行 go mod init + 模块名称 初始化模块
运行完之后,会在当前目录下生成一个go.mod文件,这是一个关键文件,之后的包的管理都是通过这个文件管理。 官方说明:除了go.mod之外,go命令还维护一个名为go.sum的文件,其中包含特定模块版本内容的预期加密哈希 注意:子目录里是不需要init的,所有的子目录里的依赖都会组织在根目录的go.mod文件里 接下来,让我们的项目依稀一下第三方包 如修改hello.go文件如下,按照过去的做法,要运行hello.go需要执行go get 命令 下载gorose包到 $GOPATH/src
但是,使用了新的包管理就不在需要这样做了
稍等片刻… go 会自动查找代码中的包,下载依赖包,并且把具体的依赖关系和版本写入到go.mod和go.sum文件中。
require 关键字是引用,后面是包,最后v1.11.1 是引用的版本号 这样,一个使用Go包管理方式创建项目的小例子就完成了。 问题一:依赖的包下载到哪里了?还在GOPATH里吗? 问题二: 依赖包的版本是怎么控制的? 版本是在go.mod中指定的。如果,在go.mod中没有指定,go命令会自动下载代码中的依赖的最新版本,本例就是自动下载最新的版本。如果,在go.mod用require语句指定包和版本 ,go命令会根据指定的路径和版本下载包, 问题三: 可以把项目放在$GOPATH/src下吗? 1.auto 自动模式下,项目在GOPATH/src的依赖包,在$GOPATH/src外,就使用go.mod 里 require的包 2.on 开启模式,1.12后,无论在$GOPATH/src里还是在外面,都会使用go.mod 里 require的包 3.off 关闭模式,就是老规矩。 问题三: 依赖包中的地址失效了怎么办?比如 golang.org/x/… 下的包都无法下载怎么办? 1.修改源码,用新路径替换import的地址 2.git clone 或 go get 新包后,copy到$GOPATH/src里旧的路径下 无论什么方法,都不便于维护,特别是多人协同开发时。 使用go.mod就简单了,在go.mod文件里用 replace 替换包,例如 replace golang.org/x/text => github.com/golang/text latest 这样,go会用 github.com/golang/text 替代golang.org/x/text,原理就是下载github.com/golang/text 的最新版本到 $GOPATH/pkg/mod/golang.org/x/text下。 问题四: init生成的go.mod的模块名称有什么用? 因为我们的项目已经不在$GOPATH/src里了,那么引用自己怎么办?就用模块名+路径。 例如,在项目下新建目录 utils,创建一个tools.go文件:
在根目录下的hello.go文件就可以 import “hello/utils” 引用utils
问题五:以前老项目如何用新的包管理
常用命令参考作者:mick_ 链接:https://www.jianshu.com/p/27c66a4c9ee8 來源:简书 简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。 指定module的根目录并生成go.mod文件
下载并添加依赖到go.mod文件中
查看module下的所有依赖
example.com/hello 更新稳定版依赖
更新为指定版本依赖
rsc.io/sampler v1.0.0 v1.2.0 v1.2.1 v1.3.0 v1.3.1 v1.99.99
清理无用的依赖
将依赖复制到项目路径的vendor文件夹中
忽略cache里的包,只使用vendor目录里的依赖进行编译
|
请发表评论