打开Terminal 定位到工程的 main.go 文件夹目录

使用命令 bee pack -be GOOS=linux 进行打包

 

将打包好的程序,放到Linux上的某个目录。

将程序放在后台运行,这里使用screen命令进行操作。一般来说,Linux都会自带了screen,如果没有,则可通过命令 sudo apt-get install screen 或 sudo yum install screen进行安装。

安装完成screen后,使用命令screen -S ***进入到screen后台界面,其中打 *** 号的是给这个屏幕建一个别名,这样好知道后台部署的程序在哪个screen的容器内。

在进入到某个screen后,就可在这里进行运行你的程序的操作。这里使用nohup进行运行,如nohup ./app &进行运行。(此处一定要在打包上传后的beego项目目录中运行 不然beego启动起来后会产生模板路径问题)

执行结束后,按键盘 ctrl+A+D键进入到前台。

需要查看有哪些screen在使用,可使用screen -ls查看。如下:


[root@izwz9j9o61ggn****hbz ~]# screen -ls
There is a screen on:
6931.golang***Api (Detached)
1 Socket in /var/run/screen/S-root.
其中,6931即为该实例的ID号。后面即可通过 screen -r 6931 再次进入到该实例进行操作。若出现使用以上命令无法进入,则使用screen -d 6931 后再次使用-r命令即可进入。

 

若使用nginx做http代理则使用beego文档上的配置即可

ps:推荐使用Supervisord来进行beego的进程管理 防止beego挂掉  教程见beego官方文档

https://beego.me/docs/deploy/supervisor.md

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

  1. 安装 setuptools
wget https://pypi.python.org/packages/2.7/s/setuptools/setuptools-0.6c11-py2.7.egg


sh setuptools-0.6c11-py2.7.egg


easy_install supervisor


echo_supervisord_conf >/etc/supervisord.conf


mkdir /etc/supervisord.conf.d
  1. 修改配置 /etc/supervisord.conf
[include]
files = /etc/supervisord.conf.d/*.conf
  1. 新建管理的应用
cd /etc/supervisord.conf.d
vim beepkg.conf

配置文件:

[program:beepkg]
directory = /opt/app/beepkg
command = /opt/app/beepkg/beepkg
autostart = true
startsecs = 5
user = root
redirect_stderr = true
stdout_logfile = /var/log/supervisord/beepkg.log
  1. 注意 directory必须配置 不然项目启动起来会报静态文件路径错误  stdout_logfile指向的文件需要提前创建

supervisord 管理

Supervisord 安装完成后有两个可用的命令行 supervisord 和 supervisorctl,命令使用解释如下:

  • supervisord,初始启动 Supervisord,启动、管理配置中设置的进程。
  • supervisorctl stop programxxx,停止某一个进程(programxxx),programxxx 为 [program:beepkg] 里配置的值,这个示例就是 beepkg。
  • supervisorctl start programxxx,启动某个进程
  • supervisorctl restart programxxx,重启某个进程
  • supervisorctl stop groupworker: ,重启所有属于名为 groupworker 这个分组的进程(start,restart 同理)
  • supervisorctl stop all,停止全部进程,注:start、restart、stop 都不会载入最新的配置文件。
  • supervisorctl reload,载入最新的配置文件,停止原有进程并按新的配置启动、管理所有进程。
  • supervisorctl update,根据最新的配置文件,启动新配置或有改动的进程,配置没有改动的进程不会受影响而重启。
  • 注意:显示用 stop 停止掉的进程,用 reload 或者 update 都不会自动重启。