关于go get 以后下载的包不在src下而在pkg的源头并且不可以import(Goland Modules模块的使用)
原因:在使用go get命令后发现下载的包不在src
目录下生成,而全部到了$GOPATH$/pkg
目录下
在下面这个目录下
最主要是下载完后,import还报错。
此时一顿baidu 猛如虎,终于找到原因所在:参考这篇文章:https://www.cnblogs.com/xiaowu54/p/14538238.html
备注:
官方在 v1.11 中加入了 Go Module 作为官方包管理形式,就这样 dep 无奈的结束了使命。
最初的 Go Module 提案的名称叫做 vgo,下面为了介绍简称为 gomod。不过在 v1.11 和 v1.12 的 Go 版本中 gomod 是不能直接使用的。
可以通过 go env 命令返回值的 GOMOD 字段是否为空来判断是否已经开启了 gomod,如果没有开启,可以通过设置环境变量
export GO111MODULE=on 开启
我的版本为1.15.6, 所以出现了这种情况
Go mod 的正确使用
如何激活Modules
首先要把go升级到1.11及以上
升级后,可以设置通过一个环境变量GO111MODULE来激活modules:
GO111MODULE=off,go命令行将不会支持module功能,寻找依赖包的方式将会沿用旧版本那种通过vendor目录或者GOPATH模式来查找。
GO111MODULE=on,go命令行会使用modules,而一点也不会去GOPATH目录下查找。
GO111MODULE=auto,默认值,go命令行将会根据当前目录来决定是否启用module功能。这种情况下可以分为两种情形:当前目录在GOPATH/src之外且该目录包含go.mod文件,或者当前文件在包含go.mod文件的目录下面。
当module功能启用时,GOPATH在项目构建过程中不再担当import的角色,但它仍然存储下载的依赖包,具体位置在$GOPATH/pkg/mod。
在你需要导入第三方包的地方,打开终端输入go mod init 命名
然后在该文件夹会出现go.mod
文件
比如打开我的代码目录---》cmd 命令,然后使用上述go mod init github.com
然后继续使用go get导入包
操作成功后,上一步动作的go mod 文件会记录导入的包名称及版本号,打开goland查看
注意:上面已经使用过go mod init之后,以后每次导入包只需要进入工作区目录,
第一步:输入“cmd”。例如:
第二步:在go项目工作区中直接使用go get命令
第三步:然后查看是否在包管理器中
最后还要一步:别忘记配置Goland Modules模块的使用
打开File--->Settings---->Go Modules(vgo) ---->然后 Enable,并输入proxy地址:https://goproxy.io
最后发现包可用了。问题解决,颜色变绿了