go

Go项目如何部署到阿里云

2019-02-27  本文已影响631人  孙小兵

Golang 项目开发结束后,如何部署到阿里云ECS,go项目部署简单很多,不会像Java 那么复杂 需要配置很多环境。

步骤如下(本文以beego项目为案例,go项目类似啦)


一 . 确认服务器环境

登录阿里云ECS,查看当前服务器系统和CPU信息 

linux 常用命令: uname -a # 查看内核/操作系统/CPU信息 

这里可以看到这个服务器的架构是 x86_64 这个架构亦称 amd64.

● 6g是amd64的go编译器,它生成的是.6文件。

● 386一般使用8g命令,它生成的一般是.8格式的文件。

● 当然还有一个5g的命令是用于arm的cpu,

同理amd64用6l,386用8l,arm用5l的链接器

明白了上面就开始交叉编译go的可执行程序了

编译对应平台下的执行文件

二 . 确认当前GO开发环境

使用 go env 命令:
(mac 下的 GOARCH 和 GOOS)

三. 交叉编译

Golang支持交叉编译,也就是说你在32位平台的机器上开发,可以编译生成64位平台上的可执行程序.mac 下可以编译linux 下的执行程序 又或者windows下的执行程序

交叉编译依赖下面几个环境变量:

$GOARCH 目标平台(编译后的目标平台)的处理器架构(386、amd64、arm)

$GOOS 目标平台(编译后的目标平台)的操作系统(darwin、freebsd、linux、windows)

到源代码目录下执行:

【beego项目编译 】

Mac 下编译linux 可执行文件

bee pack -be GOOS=linux -be GOARCH=amd64

【Go项目】

Mac 下编译 Linux 和 Windows 64位可执行程序

CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build main.go

CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build main.go

Linux 下编译 Mac 和 Windows 64位可执行程序

CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build main.go

CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build main.go

Windows 下编译 Mac 和 Linux 64位可执行程序

SET CGO_ENABLED=0

SET GOOS=darwin

SET GOARCH=amd64

go build main.go

--------------------------------------

SET CGO_ENABLED=0

SET GOOS=linux

SET GOARCH=amd64

go build main.go

备注:不带前面参数的 go build 只是编译出开发环境适用的执行文件。

四  部署到阿里云

经过以上3步后 会产生 xxx.tar.gz文件(当然 前提 不出现错误),通过工具或命令将该压缩文件发送到阿里云ECS指定的目录下;然后 登录阿里云ECS 并进入相应的目录对发送过来的文件解压缩;

解压缩成功后 可以看到2个文件:conf 、目标文件(可执行文件),运行目标文件 ,运行成功后结束;

以上是Golang项目部署到阿里云基本流程

上一篇下一篇

猜你喜欢

热点阅读