Docker搭建go开发环境
Jerry%chow 人气:0前言
对于我这种小白来说,本地环境搭建常规的操作一向是直接去go官网下载go安装包,本机进行安装,然后配置相应的GOROOT和GOPATH,再将GOPROXY和GO111MODULE设置完成,本地跑一下go env,可以正常使用就OK了。
不过,自从学习了docker之后,被深深的套路了。
说一下用docker部署本地环境的好处:
- 可以保持系统软件环境的纯净。这一点对于喜欢折腾各种工具软件,然后把系统依赖环境搞的一团糟的我来说,特别受用。
- 开发环境和当前使用系统不再强依赖。这也是我喜欢的,这样我不需要担心本地系统的各种配置文件配置,以及多个环境之间以为系统差异导致的依赖包不同造成问题,比如本地跑代码正常,线上跑不通等。
- 开发软件的管理方式更加统一。各种编程语言都有各自的安装流程和步骤,各种应用服务的安装和配置方式也各不相同。通过 Docker,不论是 MySQL,还是 Redis,我都只需要拉镜像,映射端口,然后启动容器就可以正常使用了。
所以对于go而言,我也更希望能跑在docker容器上。
那么接下来就开始吧!
安装
1.docker安装
我使用的是macOS Big Sur,在docker官网上下载对应的dmg包,也有docker desktop
下载地址推荐(下载速度快):http://get.daocloud.io/
接下来等待安装,安装的步骤就不赘述了,比较简单
完成后,打开终端,输入,docker ,出现相关命令信息,表示安装成功!
2.go安装
docker完成之后,可以到docker hub(https://hub.docker.com/)上找go的镜像
我使用目前go的新版go 1.18.1,找的镜像是 golang:1.18.1-buster,拉取:
docker pull golang:1.18.1-buster
经过等待之后,完成下载
docker images
命令可以查看本地所有的镜像,可以看到golang的镜像已经在了,接下来就可以操作了
运行这个镜像:
docker run -d --privileged=true golang
出现类似于”24bbe436b43ea9dd1da0e…“一串,说明启动成功
进入容器:
docker exec -it 24bbe436
注意:这里的容器ID是我的,你可以用容器名字或者容器ID进入
3.配置
进入容器后,接下来就是设置go的env环境变量,首先用:
go env
既是为了验证go是否可以正常运行,也是为了查看下当前go的环境变量的情况
一般初始化下,go需要自定义设置的就三个GOPATH、GOPROXY和GO111MODULE
- GOPATH:go工作目录,也是以后代码存放的地方
- GOPROXY:go包下载代理地址,为了下载包快速所改
- GO111MODULE:允许go mod 包管理工具的使用
三行代码解决!!
go env -w GO111MODULE=on #开启go mod go env -w GOPROXY="https://goproxy.cn" go env -w GOPATH="/go" #如果本身就是,那就不需要再改了,可以省略
查看下,再次 go env,是否已修改为设置的这样
自此,所有设置都完成,为了以后不重复进行设置,我们保存容器生成我们自己部署好的go环境镜像:
docker commit 24bbe43 golang-local
我将此容器重新打包为一个新的镜像,命名为golang-local,以后只要开启这个镜像,我就可以跑go代码了,当然,也可以将它传到远程hub库,用于整个项目组的基本环境搭建使用,以后协同开发的镜像都是统一的,生产也可以使用。
远程库建议使用阿里云的,具体的可以自行百度,这里就不展开了
好了,现在 docker images就可以查看到我打包的新的golang镜像,这也为后续与本机代码的使用奠定基础,接下来就是最关键的一步了。
4.运行
以上所有的步骤都是在docker里完成的,那么我们的本机与docker之间还存在着隔阂,本机放置的代码依然无法使用go环境,因为本机没有安装go,这个时候就需要用到docker经典的东东——挂载容器卷,将本地的目录与docker的容器关联起来,达到本地修改容器内的文件也可以同步修改,开始!!
先关闭之前的golang容器,docker stop 24bbe43
,因为我们不需要用到它了!
然后开启我们新镜像
docker run -itd -p 8080:8080 -v /Users/jay/go/project:/go --name golang-1.18.1 golang-local
解释下关键的命令参数:
- -p:端口映射,将docker的端口映射到本机端口,我们用8080
- -v:挂载容器卷,冒号前面是本机的地址,后面是容器内存放地址,这里需要看你本地想放哪里,任意位置都可以,前提是需要写绝对路径,注意啊,我加粗字体了。
- –name:容器别名,我主要是为以后多版本处理的话,可以看到当前容器的go版本,所以这么写,这个可以省略
好了,这样就开启了,至于说为什么是用8080,这个不需要固定,可以任意改你想要的端口号,也有个前提,与本地应用软件的使用端口不要冲突!!!
我用8080是因为我的goweb服务框架gin的默认端口就是8080,方便使用
接下来就是用gin来验证环境好不好用了
5.完成
在我的工作目录/Users/jay/go/project下,
建一个项目,就叫gin-demo吧,
然后进入gin-demo,创建一个main.go文件,
写上:
package main import ( "fmt" ) func main() { fmt.Println("Hello, Go.") }
回到容器里查看下,对应的/go目录下是不是也存在相同的文件了,做个验证
然后开始,在容器里操作,
进入到gin-demo目录下,
先验证下go代码能不能跑起来
go run main.go
出现Hello,Go. 说明正常可以跑代码了,到此处,go环境算是搭建完了。
因为我需要用的是gin框架,所以接下的事情就是gin框架的使用
go mod init
创建go.mod文件,
然后将main.go的内容改为以下:
package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run() }
最后一步,go run main.go
跑起来!!
接下来就是见证奇迹的时刻
打开浏览器,输入localhost:8080,回车!
浏览器上显示 pong,成功!
PS:go的代码运行还是需要在容器里操作,如果不想来回进出容器折腾,可以用go的一个fresh包,自动捕获代码变动重新打包运行,本地就可以快乐的写代码了,这个插件百度查下就行,这里分享一下包地址,就不细说了,我个人习惯自己去重启,比较不容易出错
go热重启go get github.com/pilu/fresh
运行 fresh 命令 ,fresh 将会自动运行项目的 main.go
到这里就结束了,个人觉得还是稍有不便,以后再整理出一份用dockerfile来部署的办法,那样就方便多了一运行就可以了,到哪都能用。
总结
加载全部内容