PM2-Python

PM2 是一个生产级流程管理器,可以轻松管理后台进程,在 Python 的世界中,PM2 是可以和 Supervisord 相媲美的,并且 PM2 还有一些非常棒的功能。

使用 PM2,让崩溃重启、观察、检查日志甚至部署应用程序,都变的简单,并且 PM2 非常重视在命令行界面的操作体验,因此 PM2 非常易于使用和掌握。

PM2 发展到今天,已经 5 年了,在 Github 上有超过 6500w 次下载,已经成为在生产服务器中运行 Node.js 的首选方式之一。但是它也支持 Python。

安装 PM2

PM2 依赖于 Node.js,所以需要提前安装 Node,这一步非常简单:

其他平台如何安装 Node.js,可自行查找教程。

有了 Node 的环境后,就可以通过 npm 来安装 PM2 了。

$ sudo npm install pm2 -g

要初始化 PM2 ,可以使用 pm2 ls 命令,此时就可以看到一个很友好的界面。

现在,已经成功安装好 PM2 了,让我们启动一个 Python 应用吧。

启动 Python

使用 PM2 启动应用非常的简单,它讲根据脚本扩展自动匹配解释器,用以运行指定的应用程序。

我们先创建一个简单的 Python 应用程序,例如:hello.py。

我们有了一个简单的 Python 脚本,接下来我们就用 PM2 去启动它。

$ pm2 start hello.py

然后在 Terminal 里就可以看到该进程了。

到这一步,这个 Python 程序就将永远的运行下去,这意味着如果该进程退出或者抛出异常,它将被自动重启。

此处的 mode 为 fork,也就是关闭当前的 Terminal 窗口,它依然可以检查到此应用的状态。

想要查看 PM2 运行管理的应用程序,可以使用 pm2 ls 命令进行查看。

检查日志

通过 PM2 运行的程序,如果想要查看 Log,可以输入 pm2 logs 命令。

如果想要指定查看某个进程的 Log,可以使用 pm2 logs <app_name> 进行指定。

另外 PM2 还提供了自动化的日志轮换功能,但是需要安装 pm2-logrotate

$ pm2 install pm2-logrotate

pm2-logrotate 将提供每天日志轮换更新的功能,并保持总的日志控件大小为 10M。

查看某进程的信息

想要查看当前使用 PM2 启动的程序的详细信息,可以使用 pm describe <app_name> 命令进行查看。

在输出中,可以看到日志文件的路径,已经解释器等信息。

管理 PM2 的进程状态

介绍完启动和查看日志,再看几个简单的管理命令。

1. 停止某个程序

$ pm2 stop hello

2. 重启某个程序

$ pm2 restart hello

3. 从进程列表中停止和删除某个程序

$ pm2 delete hello

服务器重启时,依然保持运行

使用 PM2 启动 Python 程序之后,PM2 只能保证启动的这个 Python 程序发生意外崩溃的时候,对他进行重启。如果你希望在重启服务器的时候,依然保持应用程序在线,则需要设置 init 脚本,用以告诉系统启动 PM2 以及你的应用程序。

想让 PM2 跟随系统启动,只需要运行此命令。

$ pm2 startup

startup 可以生成一个设置环境变量的命令。