小墨の博客

梦想需要付诸行动,否则只能是梦

使用pm2来保证Spring Boot应用稳定运行

Spring Boot开发web应用就像开发普通的java程序一般简洁,因为其内嵌了web容易,启动的时候只需要一条命令java -jar server.jar即可,非常方便。

但是由此而来的问题是万一应用挂了怎么办?

别担心,有pm2进程管理工具可以帮到你。

PM2简介

pm2原先是nodejs应用的进程管理工具,不过其良好的设计以及扩展性可以手动执行执行进程。


PM2安装

  1. 安装NodeJs

  2. npm install pm2 -g


PM2基本命令

pm2 list 查看所有被PM2管理的进程列表

pm2 start xxx 启动一个应用

pm2 stop xxx 停止一个应用

pm2 restart xxx 重启一个应用

pm2 describe xxx 查看应用详情

pm2 startup, pm2 save 两条命令,用来保证服务器启动时,pm2管理的程序自动运行


Java程序处理

在jar的同级目录新建应用启动配置文件,如pm2.json,内容如下:

{
    "name": "my-server",
    "script": "/usr/bin/java",
    "args": [
        "-jar",
        "server.jar"
    ],
    "exec_interpreter": "",
    "exec_mode": "fork"
}

说明如下:

name 进程名称(显示在pm2 list命令中)

script 执行进程名称,如果需要执行PHP脚本则填写php解释器的路径,本文为java

args 传给执行进程的参数,多个参数以数组单元分割

exec_interpreter NodeJs解析器,本文不适用

exec_mode 执行模式[cluster|fork]这个针对NodeJs应用的配置,非NodeJs应用统一fork


配置文件完成后,使用

pm2 start pm2.json

即可看到应用被启动


日志管理

日志路径在~/.pm2/logs,stdout和stderr被分开存放,程序中的所有stdout和stderr都被收集方便查错。





cat project-cogrowth-api.json

{
    "name": "cogrowth-api",
    "script": "java",
    "args": [
        "-Xms64m",
        "-Xmx512m",
        "-Dspring.profiles.active=pub",
        "-jar",
        "cogrowth-api-1.0.jar",
    ],
    "exec_interpreter": "",
    "exec_mode": "fork"
}


常用命令

pm2 start app.js # 启动app.js应用程序
pm2 start app.js -i 4 # cluster mode 模式启动4个app.js的应用实例
 
# 4个应用程序会自动进行负载均衡
pm2 start app.js --name="api" # 启动应用程序并命名为 "api"
pm2 start app.js --watch # 当文件变化时自动重启应用
pm2 start script.sh # 启动 bash 脚本
pm2 list # 列表 PM2 启动的所有的应用程序
pm2 monit # 显示每个应用程序的CPU和内存占用情况
pm2 show [app-name] # 显示应用程序的所有信息
pm2 logs # 显示所有应用程序的日志
pm2 logs [app-name] # 显示指定应用程序的日志
pm2 flush
 
pm2 stop all # 停止所有的应用程序
pm2 stop 0 # 停止 id为 0的指定应用程序
pm2 restart all # 重启所有应用
pm2 reload all # 重启 cluster mode下的所有应用
pm2 gracefulReload all # Graceful reload all apps in cluster mode
pm2 delete all # 关闭并删除所有应用
pm2 delete 0 # 删除指定应用 id 0
pm2 scale api 10 # 把名字叫api的应用扩展到10个实例
pm2 reset [app-name] # 重置重启数量
 
pm2 startup # 创建开机自启动命令
pm2 save # 保存当前应用列表
pm2 resurrect # 重新加载保存的应用列表
pm2 update # Save processes, kill PM2 and restore processes
pm2 generate # Generate a sample json configuration file

pm2 start app.js --node-args="--max-old-space-size=1024"

使用自定义node(而非环境变量中的node)执行脚本:
pm2 full path comm executor --   space appscript
/data/api/node/lib/node_modules/pm2/bin/pm2 start /data/api-/node/bin/node -- /data/api/bin/www
 
pm2 start a node-app with its own execEnv.  -- means attach args to prev executor
 
pm2 启动java项目:
pm2 start java -- -jar xxx.jar
 
按CPU启动多核:
pm2 -i 0 start java -- -jar xxx.jar 
 
pm2 启动脚本并制定运行环境:
pm2 start ./start.json --name nm  --env production


自动重启

sudo pm2 start xxxx  // 启动服务
sudo pm2 save // 保存服务
sudo pm2 startup // 把已启动服务加到systemd中
sudo systemctl reboot // 重启,发现之前的服务都已经启动
sudo pm2 unstartup systemd // 删除自动启动服务
 
如果不生效:
 
请检查是否是以sudo执行,或者是用su用户操作
pm2 save 之后的文件是否有内容
应用依赖的其它进程是否应启动完成,例如数据库在执行
 
pm2 unstartup systemd
之前,即使已经pm2 delete app,重启后依然会启动服务。
 
注:自动启动适用于稳定代码版本,如果代码发生变动,需要重新save、startup,否则pm2启动可能报错:
 
path.js:1144
cwd = process.cwd();
^
Error: ENOENT: no such file or directory, uv_cwd
    at Error (native)
    at Object.resolve (path.js:1144:25)
    at Function.Module._resolveLookupPaths (module.js:361:17)
    at Function.Module._resolveFilename (module.js:431:31)
    at Function.Module._load (module.js:388:25)
    at Module.require (module.js:468:17)
    at require (internal/module.js:20:19)
    at Object. (/usr/lib/node_modules/pm2/lib/ProcessContainer.js:12:15)
    at Module._compile (module.js:541:32)
    at Object.Module._extensions..js (module.js:550:10)



原文链接:https://www.ddhigh.com/2017/07/30/spring-boot-pm2.html

张小弟之家

本文链接:
文章标题:

本站文章除注明转载/出处外,均为原创,若要转载请务必注明出处。转载后请将转载链接通过邮件告知我站,谢谢合作。本站邮箱:admin@only4.work

尊重他人劳动成果,共创和谐网络环境。点击版权声明查看本站相关条款。

    发表评论:

    搜索
    本文二维码
    标签列表
    站点信息
    • 文章总数:508
    • 页面总数:20
    • 分类总数:92
    • 标签总数:208
    • 评论总数:61
    • 浏览总数:225323

    | | |
    | |  Z-Blog PHP