博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Golang项目部署
阅读量:6080 次
发布时间:2019-06-20

本文共 4294 字,大约阅读时间需要 14 分钟。

文章来源:

一、独立部署

使用GF开发的应用程序可以独立地部署到服务器上,设置为后台守护进程运行即可。这种模式常用在简单的API服务项目中。

服务器我们推荐使用*nix服务器系列(包括:Linux, MacOS, *BSD),以下使用Ubuntu系统为例,介绍如何部署使用GF框架开发的项目。

1. nohup

我们可以使用简单的nohup命令来运行应用程序,使其作为后台守护进程运行,即使远程连接的SSH断开也不会影响程序的执行。在流行的Linux发行版中往往都默认安装好了nohup命令工具。

命令如下:

nohup ./gf-app &

2. tmux

tmux是一款Linux下的终端复用工具,可以开启不同的终端窗口来将应用程序作为后台守护进程执行,即使远程连接的SSH断开也不会影响程序的执行。

ubuntu系统下直接使用sudo apt-get install tmux安装即可。使用以下步骤将应用程序后台运行。

  1. tmux new -s gf-app
  2. 在新终端窗口中执行./gf-app即可;
  3. 使用crt + B & D快捷键可以退出当前终端窗口;
  4. 使用tmux attach -t gf-app可进入到之前的终端窗口;

3. supervisor

supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。官方网站:

常见配置如下:

[program:gf-app]user=rootcommand=/var/www/mainstdout_logfile=/var/log/gf-app-stdout.logstderr_logfile=/var/log/gf-app-stderr.logautostart=trueautorestart=true

使用步骤如下:

  1. 使用sudo service supervisor start启动supervisor服务;
  2. 创建应用配置文件/etc/supervisor/conf.d/gf-app.conf, 内容如上;
  3. 使用sudo supervisorctl进入supervisor管理终端;
  4. 使用reload重新读取配置文件并重启当前supoervisor管理的所有进程;
  5. 也可以使用update重新加载配置(默认不重启),随后使用start gf-app启动指定的应用程序;
  6. 随后可以使用status指令查看当前supervisor管理的进程状态;

二、代理部署

代理部署即前置一层第三方的WebServer服务器处理所有的请求,将部分请求(往往是动态处理请求)有选择性地转交给后端的Golang应用程序执行,后端部署的Golang应用程序可以配置有多个。这种模式常用在复杂的WebServer配置中,常见的场景例如:需要静态文件分离、需要配置多个域名及证书、需要自建负载均衡层,等等。

虽然
Golang实现的
WebServer也能够处理静态文件,但是相比较于专业性的
WebServer
nginx/
apache来说比较简单,性能也较弱。因此不推荐使用
Golang WebServer作为前端服务直接处理静态文件请求。

Nginx

我们推荐使用Nginx作为反向代理的前端接入层,有两种配置方式实现动静态请求的拆分。

静态文件后缀

这种方式通过文件名后缀区分,将指定的静态文件转交给nginx处理,其他的请求转交给golang应用。

配置示例如下:

server {    listen       80;    server_name  goframe.org;    access_log   /var/log/gf-app-access.log;    error_log    /var/log/gf-app-error.log;    location ~ .*\.(gif|jpg|jpeg|png|js|css|eot|ttf|woff|svg|otf)$ {        access_log off;        expires    1d;        root       /var/www/gf-app/public;        try_files  $uri @backend;    }    location / {        try_files $uri @backend;    }    location @backend {        proxy_pass                 http://127.0.0.1:8199;        proxy_redirect             off;        proxy_set_header           Host             $host;        proxy_set_header           X-Real-IP        $remote_addr;        proxy_set_header           X-Forwarded-For  $proxy_add_x_forwarded_for;    }}

其中,8199为本地的golang应用WebServer监听端口。

例如,在该配置下,我们可以通过http://goframe.org/my.png访问到指定的静态文件。

静态文件目录

这种方式通过文件目录区分,将指定目录的访问请求转交给nginx处理,其他的请求转交给golang应用。

配置示例如下:

server {    listen       80;    server_name  goframe.org;    access_log   /var/log/gf-app-access.log;    error_log    /var/log/gf-app-error.log;    location ^~ /public {        access_log off;        expires    1d;        root       /var/www/gf-app;        try_files  $uri @backend;    }    location / {        try_files $uri @backend;    }    location @backend {        proxy_pass                 http://127.0.0.1:8199;        proxy_redirect             off;        proxy_set_header           Host             $host;        proxy_set_header           X-Real-IP        $remote_addr;        proxy_set_header           X-Forwarded-For  $proxy_add_x_forwarded_for;    }}

其中,8199为本地的golang应用WebServer监听端口。

例如,在该配置下,我们可以通过http://goframe.org/piblic/my.png访问静态文件。

三、容器部署

容器部署即使用docker化部署golang应用程序,这是在云服务时代最流行的部署方式,也是最推荐的部署方式。

1. 编译程序

跨平台交叉编译是golang的特点之一,可以非常方便地编译出我们需要的目标服务器平台的版本,而且是静态编译,非常方便地解决了运行依赖问题。

使用以下方式静态编译Linux平台amd64架构的可执行文件:

CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o gf-app main.go

这样便编译出来一个gf-app的可执行文件。

2. 编译镜像

我们需要将该可执行文件gf-app编译生成docker镜像,以便于分发及部署。Golang的运行环境推荐使用alpine基础系统镜像,编译出的容器镜像约为20MB左右。

一个参考的Dockerfile文件如下( 可以参考gf-home项目的Dcokerfile: ):

FROM loads/alpine:3.8LABEL maintainer="john@johng.cn"################################################################################                                INSTALLATION###############################################################################ADD ./gf-app /bin/mainRUN chmod +x /bin/main################################################################################                                   START###############################################################################CMD main

其中,我们的基础镜像使用了loads/alpine:3.8这个镜像,基础镜像的Dockerfile地址: ,仓库地址:

随后使用 docker build gf-app . 命令编译生成名为gf-appdocker镜像。

3. 运行镜像

使用以下命令运行镜像:

docker run gf-app

4. 镜像分发

容器的分发可以使用docker官方的平台: ,国内也可以考虑使用阿里云: 。

5. 容器编排

在企业级生产环境中,docker容器往往需要结合kubernetes或者docker swarm容器编排工具一起使用。

容器编排涉及到的内容比较多,感兴趣的同学可以参考以下资料:

转载地址:http://trhgx.baihongyu.com/

你可能感兴趣的文章
iOS下的WiFi开发
查看>>
Integer与int的区别
查看>>
如何判断字段是否存在,如何删除及创建字段
查看>>
自动运行
查看>>
关于WEB单片机编程的网站
查看>>
ubuntu16.04 eclipse+pydev 配置
查看>>
通过rtinst脚本安装Rtorrent+rutorrent(附版本切换教程)
查看>>
JS,Jquery获取各种屏幕的宽度和高度
查看>>
MVC笔记 MVC注意事项及优化
查看>>
jmeter基本组成原件介绍
查看>>
web学习--java applets
查看>>
Android布局控件之LinearLayout
查看>>
Java NIO 选择器(Selector)的内部实现(poll epoll)(转)
查看>>
(转)NIO 文件锁定
查看>>
多态(1)静态多态与动态多态以及虚函数相关
查看>>
Oakley Sunglasses – Useful Information About Oakley Sunglasses
查看>>
[转载]html5教程
查看>>
Notification 使用详解(很全
查看>>
android-数据库操作实例,留着以后用
查看>>
Q85 最大矩形
查看>>