现象:在Goland IDE中无法正常运行哪怕是最简单的iris框架,报找不到iris包的错误,而且代码中的import也是红色的。但是,同样的代码在cmd命令行下手动 build 又一切正常。更甚的是,在Goland自己内置的Terminal中执行与它自身自动产生的build指令居然也能成功,但当你按下【运行】按钮,跑同样的build指令就是不行,头大。
分析:在Goland中,旧的gopath包管理模式和新款的go mod模式有冲突。
第一部分. go mod的设置
1. 因为我们打算采用go mod做包管理,因此可以无视GOPATH,(PS:GOPATH现在它的唯一作用是作为一个仓库,保存通过go mod自动下载的包,这些包全部集中在GOPATH的pkg目录下),除此之外,这个路径已经和我们的项目没有关系了,你不必非要在GOPATH的指定路径下建立项目,随便找个地方都行 (下面以d:\iris为例):
d:
md iris
cd iris
编辑一段最简单的iris测试代码:
package main
import (
"github.com/kataras/iris"
"github.com/kataras/iris/middleware/logger"
"github.com/kataras/iris/middleware/recover"
)
func main() {
app := iris.New()
app.Logger().SetLevel("debug")
app.Use(recover.New())
app.Use(logger.New())
app.Get("/", func (ctx iris.Context){
ctx.HTML("Hello")
})
app.Run(iris.Addr(":8080"), iris.WithoutServerError(iris.ErrServerClosed))
}
存盘,文件名存为iris.go
2. 初始化go mod:
go mod init iris.go
系统显示 go: creating new go.mod: module iris.go ,说明创建成功。
3. 注意,此时和以前不太相同了,使用go mod后,就不再需要go get之类指令去获取相关依赖包,go mod会自动根据代码中的import去下载相应的依赖包,直接build即可:
4. 输入以下命令开始编译:
set GOPROXY=https://goproxy.io
go build iris.go
编译完毕后,生成iris.exe文件,运行一下,正常情况会显示:
D:\iris>iris
[DBUG] 2019/12/28 18:38 GET: / -> main.main.func1() and 2 more
[DBUG] 2019/12/28 18:38 Application: running using 1 host(s)
[DBUG] 2019/12/28 18:38 Host: addr is :8080
[DBUG] 2019/12/28 18:38 Host: virtual host is localhost:8080
[DBUG] 2019/12/28 18:38 Host: register startup notifier
[DBUG] 2019/12/28 18:38 Host: register server shutdown on interrupt(CTRL+C/CMD+C)
[DBUG] 2019/12/28 18:38 Host: server will ignore the following errors: [http: Server closed]
Now listening on: http://localhost:8080
Application started. Press CTRL+C to shut down.
第二部分. Goland 的设置
1. 打开goland,选择open一个项目
2. 就选我们刚才在D盘建立的D:\iris
3. File菜单,选Settings , 设置一下GOROOT和Go Modules,此处的GOPATH请忽略,否则会与go mod发生冲突:
4. 此时回到主编辑区,点开iris.go文件,你会发现import一片红,这是正常的,先不管这个,我们先把运行环境设好,点击此处:
5. 按图设置:
6. 此时代码其实可以运行了,但是import还是红色,因为Goland要执行一个C:\Go\bin\go.exe list -m -json all,这条命令是比较慢的,不用着急,让它慢慢跑就是了(界面右下方有一个很细的进度条)
- 最终代码区的import会全部变成绿色,完美解决问题!