zoukankan      html  css  js  c++  java
  • nodejs部署配置pm2

    高大上先上部署node方式:

    直接通过node app来启动,如果报错了可能直接停在整个运行,

    supervisor感觉只是拿来用作开发环境的。

    目前似乎最常见的线上部署nodejs项目的有forever,pm2这两种。

    使用场合:

    • supervisor是开发环境用。
    • forever管理多个站点,每个站点访问量不大,不需要监控。
    • pm2 网站访问量比较大,需要完整的监控界面

    pm2主要特性:

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

    使用npm/cnpm全局安装:

    npm install -g pm2
    

    pm2命令使用(项目更目录下使用):

    $ pm2 start app.js  启动app项目

    $ pm2 list 列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。

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

    $ 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 杀死全部进程

    启动进程的方式详细:

    $ 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 启动 并 生成一个配置文件

    配置pm2启动文件:

    可以通过pm2 start processes.json来启动。

    在项目根目录下添加文件processes.json:

    {
     "apps": [
     {
      "name": "mywork",
      "cwd": "/srv/node-app/current",
      "script": "bin/xxx",
      "log_date_format": "YYYY-MM-DD HH:mm:ss",
      "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
     }
     ]
    }

    processes.json说明:

    • 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特性(版本控制)

    也可以把启动命令写在package.json里:

    "scripts": {
    "start": "node ./bin/xxx",
    "pm2":"pm2 start processes.json"
    },
  • 相关阅读:
    C语言 realloc为什么要有返回值,realloc返回值具体解释/(解决随意长度字符串输入问题)。
    opencv中的vs框架中的Blob Tracking Tests的中文注释。
    Java实现 蓝桥杯VIP 算法提高 棋盘多项式
    Java实现 蓝桥杯VIP 算法提高 棋盘多项式
    Java实现 蓝桥杯VIP 算法提高 棋盘多项式
    Java实现 蓝桥杯VIP 算法提高 棋盘多项式
    Java实现 蓝桥杯VIP 算法提高 分苹果
    Java实现 蓝桥杯VIP 算法提高 分苹果
    Java实现 蓝桥杯VIP 算法提高 分苹果
    Java实现 蓝桥杯VIP 算法提高 分苹果
  • 原文地址:https://www.cnblogs.com/minutes/p/11020130.html
Copyright © 2011-2022 走看看