zoukankan      html  css  js  c++  java
  • PM2 使用手册

    为什么要用pm2

    因为node.js 是单进程,进程被杀死后整个服务就跪了,所以需要进程管理工具。

    pm2是一个进程管理工具,可以用它来管理你的node进程,并查看node进程的状态,当然也支持性能监控,进程守护,负载均衡等功能

    介绍

    PM2 是一个带有负载均衡功能的 Node 应用的进程管理器。

    当你要把你的独立代码利用全部的服务器上的所有 CPU,并保证进程永远都活着,0 秒的重载, PM2 是完美的。

    特性

    • 内建负载均衡(使用Node cluster 集群模块)
    • 后台运行
    • 0秒停机重载(维护升级的时候不需要停机).
    • 具有Ubuntu和CentOS 的启动脚本
    • 停止不稳定的进程(避免无限循环)
    • 控制台检测
    • 提供 HTTP API
    • 远程控制和实时的接口API ( Nodejs 模块,允许和PM2进程管理器交互 )

    安装

    #先安装nodejs
    npm install -g pm2
    

    运行

     pm2 start app.js --name my-api # 命名进程
     pm2 start app.js -i max  # 根据有效CPU数目启动最大进程数目
     pm2 start app.js -i 3      # 启动3个进程
     pm2 start app.js -x        #用fork模式启动 app.js 而不是使用 cluster
     pm2 start app.js -x -- -a 23   # 用fork模式启动 app.js 并且传递参数 (-a 23)
     pm2 start app.js --name serverone  # 启动一个进程并把它命名为 serverone
     pm2 stop serverone       # 停止 serverone 进程
     pm2 start app.json        # 启动进程, 在 app.json里设置选项
     pm2 start app.js -i max -- -a 23                   #在--之后给 app.js 传递参数
     pm2 start app.js -i max -e err.log -o out.log  # 启动 并 生成一个配置文件,你也可以执行用其他语言编写的app  ( fork 模式):
     pm2 start my-bash-script.sh    -x --interpreter bash
     pm2 start my-python-script.py -x --interpreter python
    
     pm2 list               # 显示所有进程状态
     pm2 monit              # 监视所有进程
     pm2 logs               #  显示所有进程日志
     pm2 stop all           # 停止所有进程
     pm2 restart all        # 重启所有进程
     pm2 reload all         # 0秒停机重载进程 (用于 NETWORKED 进程)
     pm2 stop 0             # 停止指定的进程
     pm2 restart 0          # 重启指定的进程
     pm2 startup            # 产生 init 脚本 保持进程活着
     pm2 web                # 运行健壮的 computer API endpoint (http://localhost:9615)
     pm2 delete 0           # 杀死指定的进程
     pm2 delete all         # 杀死全部进程
    

    监听node进程

    pm2 start app.js 或者 pm2 start bin/www 启动node项目
    pm2 list 列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。

    img

    pm2.png

    pm2 monit 监视每个node进程的CPU和内存的使用情况

    img

    monit.png

    配置pm2启动文件

    在项目根目录添加一个processes.json:
    内容如下:

    {
      "apps": [
        {
          "name": "mywork",
          "cwd": "/srv/node-app/current",
          "script": "bin/www",
          "log_date_format": "YYYY-MM-DD HH:mm Z",
          "error_file": "/var/log/node-app/node-app.stderr.log",
          "out_file": "log/node-app.stdout.log",
          "pid_file": "pids/node-geo-api.pid",
          "instances": 6,
          "min_uptime": "200s",
          "max_restarts": 10,
          "max_memory_restart": "1M",
          "cron_restart": "1 0 * * *",
          "watch": false,
          "merge_logs": true,
          "exec_interpreter": "node",
          "exec_mode": "fork",
          "autorestart": false,
          "vizion": false
        }
      ]
    }
    

    说明:

    • apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用

    • name:应用程序名称

    • cwd:应用程序所在的目录

    • script:应用程序的脚本路径

    • log_date_format:

    • error_file:自定义应用程序的错误日志文件

    • out_file:自定义应用程序日志文件

    • pid_file:自定义应用程序的pid文件

    • instances: 实例数

    • min_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量

    • max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)

    • cron_restart:定时启动,解决重启能解决的问题

    • watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。

    • merge_logs: 合并日志

    • exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejs

    • exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork

    • autorestart:启用/禁用应用程序崩溃或退出时自动重启

    • vizion:启用/禁用vizion特性(版本控制)

      可以通过

      pm2 start processes.json
      

      来启动。

      也可以把命令写在package.json里。如下:

      img

    一个幽默的前端爱好者,记录下自己的心得体会
  • 相关阅读:
    docker 基于现有镜像修改后保存,上传私有仓库
    新装docker 从本地仓库下载
    decode_json 必须是unicode形式的字符
    浅谈消息队列的原理及优势
    javascript基础修炼(10)——VirtualDOM和基本DFS
    消息队列属性及常见消息队列介绍
    【Angular专题】——【译】Angular中的ForwardRef
    单体应用微服务改造实践
    SpringCloud微服务2-服务提供者和消费者
    基于CSE的微服务工程实践-Native API先行
  • 原文地址:https://www.cnblogs.com/little-oil/p/14751023.html
Copyright © 2011-2022 走看看