我就想试试github.com/gin-gonic/gin,为什么死活都run不起来

准备学习go语言,打算用go的gin框架来写写web接口。然而用文档的教程来运行,却死活都跑不起来,写下问题和解决方法,让遇到问题的同伴早日脱离苦海

首先简单的说下正常要运行一个项目步骤,我是windows环境:

 安装golang

1. 下载安装包安装

2. 在cmd中输入go回车,有输出则说明安装正常

3. 一般安装的时候程序会自动添加,无需人工干预

检查GOPATH

1. 可以在cmd中查看set GOPATH

2. 或者在"我的电脑"-"属性"-"高级"-"环境变量"中查看和添加

3. 正常go安装,会自动添加,我本机GOPATH=C:\Users\Administrator\go;

安装gin

1. 接下来安装gin,框架文档介绍:go get -u github.com/gin-gonic/gin

2. 这时候开始遇到问题了,常遇问题资源加载不了,解决方法是使用代理(这块有个 go env 的命令,可以查看当前配置),在cmd中运行:

  go env -w GO111MODULE=on

   go env -w GOPROXY=https://goproxy.io,direct

3. 设置后,重新运行: go get -u github.com/gin-gonic/gin,可以很快速的安装

运行项目 

1. 在C:\Users\Administrator\go\ 下创建 src/gin/ 文件夹,创建main.go 文件,添加文档说的代码

package main

import "github.com/gin-goinc/gin"

func main() {

        r := gin.Default()

        r.GET("/ping", func(c *gin.Context) {

                  c.JSON(200, gin.H{

                               "message": "pong",

                  })

         })

        r.Run() // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")

}

2. 在cmd中,进入C:\Users\Administrator\go\src\gin\目录,运行命令:  go run .\main.go

3. 这时候问题又来了,报错:main.go:3:8: cannot find module providing package github.com/gin-gonic/gin: working directory is not part of a module

4. 解决方法,当前目录分别运行下面两句代码:

  go mod init gin

  go mod edit -require github.com/gin-gonic/gin@latest

5. 上面运行后,再运行  go run .\main.go,就可行了。这其中涉及到go mod包依赖管理 ,类似前端npm的package.json,有兴趣可以深入了解

问题回顾

上面几点只是说明解决方法,这其中遇到的问题,甚至一度怀疑我安装的版本有问题

1. 我使用的是go 1.14.2,在运行gin的时候 go run .\main.go ,会报错: main.go:3:8: cannot find module providing package github.com/gin-gonic/gin: working directory is not part of a module

2. 此时经过几次调试,发现如果运行 go env -w GO111MODULE=off(关闭模块管理)报错变成

main.go:3:8: cannot find package "github.com/gin-gonic/gin" in any of: c:\go\src\github.com\gin-gonic\gin (from $GOROOT) C:\Users\Administrator\go\src\github.com\gin-gonic\gin (from $GOPATH)

3. 这时 cannot find package "" in any of 这个报错,就把我引到到设置GOPATH问题集合上,调试很久,发现并不能解决

4. 此时我怀疑起了代理设置,特别是go get 之后包是放在  $GOPATH\src\pkg下的,教程说是在src下面的,这点很是诡异, 当 go env -w GO111MODULE=off (关闭模块管理),这个时候go get 命令是不走代理,而是走实际地址,下载速度异常慢,经常下载失败,但是模块包能被下载到 $GOPATH/src目录下,这点和网上说的go目录结构一致,此时在main.go中 import 包,运行也不会报错( gin的包比较大,正常是下载失败的,我当时用go get github.com/astaxie/beedb试了另一个包)

5. gin用go get 下载是不会成功的,我直接在github下载包放在 $GOPATH/src 下,但是缺少依赖,无法运行,后续又把 $GOPATH\src\pkg\mod中的包复制到 $GOPATH\src,还是不能运行。

6. 最后发现gin中有个go.mod的文件,查阅了相关资料,才找到解决方法。

总结

     在使用 GOPROXY 的时候,开启了 GO111MODULE,导致包管理非官方所说的在  $GOPATH\src\,而是去了 $GOPATH\src\pkg\目录下,此时就需要用go mod引入这些包 require github.com/gin-gonic/gin@latest ,解决import获取不了包的问题。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351