1

pm2运行json文件启动node项目及pm2-web的安装

定义运行配置文件

我们可以预定义一个配置文件,然后制定运行这个配置文件,比如我们定义一个文件app.json,内容如下:

[root@jenkins-master linux]# cat app.json   
{
"apps":[
    {
      "name": "service-sk_platform_professional_dev",
      "cwd": "/data/source/service-sk_platform_professional_dev/publish/",
      "script": "/data/source/service-sk_platform_professional_dev/publish/service/server.js",
      "log_date_format": "YYYY-MM-DD HH:mm Z",
      "error_file": "/data/pm2-log/errlogs/service-sk_platform_professional_dev-err.log",
      "out_file": "/data/pm2-log/outlogs/service-sk_platform_professional_dev-out.log",
      "pid_file": "/data/pm2-log/outlogs/service-sk_platform_professional_dev.pid",
      "instances": 1,
      "node_args": "--inspect=0.0.0.0:33111",
      "min_uptime": "20s",
      "max_restarts": 50,
      "watch": false,
      "merge_logs": true,
      "exec_interpreter": "node",
      "exec_mode": "fork",
    }
    ]
}
[root@node-44 ~]# cat app.json 
{
  "apps":[
    {
      "name": "sk_service_calculate_convert_dev",
      "cwd": "/data/source/sk_service_calculate_convert_dev/publish/",
      "script": "/data/source/sk_service_calculate_convert_dev/publish/service/server.js",
      "log_date_format": "YYYY-MM-DD HH:mm Z",
      "error_file": "/data/pm2-log/errlogs/sk_service_calculate_convert_dev-err.log",
      "out_file": "/data/pm2-log/outlogs/sk_service_calculate_convert_dev-out.log",
      "pid_file": "/data/pm2-log/outlogs/sk_service_calculate_convert_dev.pid",
      "instances": 1,
      "min_uptime": "20s",
      "max_restarts": 50,
      "watch": false,
      "merge_logs": true,
      "exec_interpreter": "node",
      "exec_mode": "fork",
},{
      "name": "sk_service_calculate_convert_dev2",
      "cwd": "/data/source/sk_service_calculate_convert_dev/publish/",
      "script": "/data/source/sk_service_calculate_convert_dev/publish/service/server.js",
      "args": "'debug' '12345'",
      "log_date_format": "YYYY-MM-DD HH:mm Z",
      "error_file": "/data/pm2-log/errlogs/sk_service_calculate_convert2_dev-err.log",
      "out_file": "/data/pm2-log/outlogs/sk_service_calculate_convert2_dev-out.log",
      "pid_file": "/data/pm2-log/outlogs/sk_service_calculate_convert2_dev.pid",
      "instances": 1,
      "min_uptime": "20s",
      "max_restarts": 50,
      "watch": false,
      "merge_logs": true,
      "exec_interpreter": "node",
      "exec_mode": "fork",
  },{
      "name": "sk_service_calculate_convert_dev3",
      "cwd": "/data/source/sk_service_calculate_convert_dev/publish/",
      "script": "/data/source/sk_service_calculate_convert_dev/publish/service/server.js",
      "args": "'debug' '12344'",
      "log_date_format": "YYYY-MM-DD HH:mm Z",
      "error_file": "/data/pm2-log/errlogs/sk_service_calculate_convert3_dev-err.log",
      "out_file": "/data/pm2-log/outlogs/sk_service_calculate_convert3_dev-out.log",
      "pid_file": "/data/pm2-log/outlogs/sk_service_calculate_convert3_dev.pid",
      "instances": 1,
      "min_uptime": "20s",
      "max_restarts": 50,
      "watch": false,
      "merge_logs": true,
      "exec_interpreter": "node",
      "exec_mode": "fork",
  },{
      "name": "sk_service_calculate_convert_dev4",
      "cwd": "/data/source/sk_service_calculate_convert_dev/publish/",
      "script": "/data/source/sk_service_calculate_convert_dev/publish/service/server.js",
      "args": "'debug' '12343'",
      "log_date_format": "YYYY-MM-DD HH:mm Z",
      "error_file": "/data/pm2-log/errlogs/sk_service_calculate_convert4_dev-err.log",
      "out_file": "/data/pm2-log/outlogs/sk_service_calculate_convert4_dev-out.log",
      "pid_file": "/data/pm2-log/outlogs/sk_service_calculate_convert4_dev.pid",
      "instances": 1,
      "min_uptime": "20s",
      "max_restarts": 50,
      "watch": false,
      "merge_logs": true,
      "exec_interpreter": "node",
      "exec_mode": "fork",
  }
]
}
for (int i = 0;i<"${node_number}".toInteger();i++){
                     Integer nodeport=10000+i
                        sh "cat /data/ansible/playbook/linux/linux_app.json |sed -e 's/sourcepath_node_Jenvironment/${projectname}_${environment}_${i}/g' -e 's/sourcepath_Jenvironment/${projectname}_${environment}/g' -e 's/process_mode/${process_mode}/g' -e 's/node_port/${nodeport}/g' >>${WORKSPACE}/publish/app.json"
                        sh(script: "echo -n ',\r\n' >>${WORKSPACE}/publish/app.json")
                    
                    }
  • 然后可以通过,运行这个App。

pm2 start app.json

apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用  
name:应用程序名称  
args:脚本的参数域
cwd:应用程序所在的目录  
script:应用程序的脚本路径  
log_date_format:
node_args:node 的参数域  
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

npm install -g pm2

  • 启动应用

pm2 start app.js

  • 列出所有应用

pm2 list

  • 查看资源消耗

pm2 monit

  • 查看某一个应用状态

pm2 describe [app id]

  • 查看所有日志

pm2 logs

  • 重启应用

pm2 restart [app id]

  • 停止应用

pm2 stop [app id]

  • 开启api访问

pm2 web

安装pm2-web

安装软件

安装时需要g++,make等软件,下面的软件你自己挑(我是刚装完系统就都装了)

yum -y install ntpdate lrzsz tree cmake gcc gcc-c++ autoconf l libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel libxslt-devel libtool-ltdl-devel make wget docbook-dtds asciidoc e2fsprogs-devel gd gd-devel openssl openssl-devel lsof git unzip gettext-devel gettext libevent libevent-devel pcre pcre-devel

npm install --unsafe-perm -g pm2-web

  
pm2-web

配置启动文件

[root@localhost ~]# cat pm2-web-config.json 

{  
    "www": {  
        "host": "localhost",  
        "address": "0.0.0.0",  
        "port": 11111  
    }                           
}

[root@localhost ~]# cat pm2-web-start.sh

  
nohup pm2-web --config pm2-web-config.json >pm2-web.log&

  
[root@localhost ~]# sh +x   pm2-web-start.sh

clipboard.png

server {  
        listen 80;  
        server_name pm2-web.xxxx.com;  
        access_log /data/nginx/logs/node-web.xxx.com/node-web.xxxx.com.log main;  
        location / {  
                auth_basic              "node-web monitor";                                                                        
                auth_basic_user_file    /data/nginx/htpasswd.conf;  //设置用户访问控制  
                proxy_pass http://192.168.0.xxx:xxxx;  
                proxy_redirect off;  
                proxy_set_header Host $http_host;  
                proxy_set_header X-Real-IP $remote_addr;  
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
                proxy_http_version 1.1;  
                proxy_set_header Upgrade $http_upgrade;  
                proxy_set_header Connection "upgrade";  
                proxy_connect_timeout 360;  
                proxy_send_timeout 360;  
                proxy_read_timeout 360;  
        }  
}

锅包肉
89 声望17 粉丝

这个人很懒,没有什么说的。