第一步、搭建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部署