前言

对于我这种小白来说,本地环境搭建常规的操作一向是直接去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来部署的办法,那样就方便多了一运行就可以了,到哪都能用。

感谢你耗时观看,如果可以的话,关注一下下哦!

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐