第一步、搭建Go生产环境

1.下载包

https://golang.org/dl/

2.解压(有1.14.4版本了,tar -zxvf后回有个go文件夹)

cd /usr/local/

wget https://dl.google.com/go/go1.13.6.linux-amd64.tar.gz

tar -xf go1.13.6.linux-amd64.tar.gz ./go-1.13

vim /etc/profile

export PATH=/usr/local/go-1.13/bin:$PATH

source /etc/profile

3.测试环境

vim hello.go

package main

import "fmt"

func main(){

fmt.Println("Hello World!")

}

4.运行

go run hello.go

允许结果:Hello World!

 

说明:

在/etc/profile文件末尾添加以下配置,输入 :wq保存

这里的GO111MODULE配置是go1.11后出的一种新的包管理go modules方式代替vendor机制,可以不需要GOPATH,项目代码也不一定要放在GOPATH下面 可参考https://www.cnblogs.com/apocelipes/p/9534885.html

GO111MODULE=auto 自动

GO111MODULE=on 使用go modules,不会在vendor和gopath找依赖 【推荐新版都用这种】

GO111MODULE=off 使用vendor 或者gotpath

注意:下面的GO111MODULE可以不需要配置了

#golang env config export GO111MODULE=on export GOROOT=/usr/local/go export GOPATH=/home/gopath export PATH=$PATH:$GOROOT/bin:$GOPATH/bin

雷小天博客

第二步、上传go项目文件

注意vendor文件夹不用上传,可在Linux环境重新下载到vendor中(vendor不做版本控制)

雷小天博客

第三步、配置go module依赖管理工具

如果第一步没有配置module依赖,那么这步我们就需要配置,如下图就是没有配置

雷小天博客

配置步骤如下:如果您使用的 Go 版本是 1.13 及以上 (推荐)

go env -w GO111MODULE=on

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

配置后,再查看是否成功,有数据表示成功

雷小天博客

第四步、打包项目并启动

第三步配置好module依赖工具时,我们切换到我们项目目录(/data/gopath/Irispom)

4.1下载依赖:go mod tidy(当然目录下已经有go.mod文件,没有的话go mod init,一般用户modules方式创建时都会有)

雷小天博客

go modules 方式

雷小天博客

常用的go mod命令如下:

 

go mod download 下载依赖的module到本地cache(默认为$GOPATH/pkg/mod目录)

go mod edit 编辑go.mod文件

go mod graph 打印模块依赖图

go mod init 初始化当前文件夹, 创建go.mod文件

go mod tidy 增加缺少的module,删除无用的module

go mod vendor 将依赖复制到vendor下

go mod verify 校验依赖

go mod why 解释为什么需要依赖

4.2复制依赖到vendor

go mod vendor

4.3build打包项目

go build Irispom打包项目,Irispom是项目名称,一般是文件夹名称,打包可生产Irispom二进制可执行文件

雷小天博客

4.4独立部署,运行项目

./Irispom 运行项目,当然你可以后台运行:nohup ./Irispom &

nohup go run main.go > /var/log/gintest.log &

nohup ./Irispom > /var/log/gorun.log &

雷小天博客

这种方式只是独立部署,还可以:Supervisor部署 Nginx部署 Apache部署