nodejs pm2教程

一、简介

pm2是一个带有负载均衡功能的应用进程管理器,类似有Supervisor,forever。

二、安装

Linux Binaries下载地址:https://nodejs.org/dist

cdoneinstack/src

wget https://nodejs.org/dist/v4.2.4/node-v4.2.4-linux-x64.tar.gz

tar xzf node-v4.2.4-linux-x64.tar.gz

cp node-v4.2.4-linux-x64/bin/node /usr/local/bin/

cp -R node-v4.2.4-linux-x64/lib/node_modules /usr/local/lib/

ln -s /usr/local/lib/node_modules/npm/bin/npm-cli.js /usr/local/bin/npm

npm install pm2@latest -g #安装最新版本pm2模块

PS: 如果你的主机无法连接公网,先找到能连公网的主机安装上面的方法安装pm2,然后拷贝到你要安装的主机。拷贝如下目录:

/usr/local/bin/node

/usr/local/lib/node_modules

再创建相关软连接

三、PM2常用命令

假设你现在已经写好了一个app.js的文件,需要启动,你可以使用pm2进行管理

1. 启动

# pm2 start app.js

# pm2 start app.js --name my-api#my-api为PM2进程名称

# pm2 start app.js -i 0#根据CPU核数启动进程个数

# pm2 start app.js --watch#实时监控app.js的方式启动,当app.js文件有变动时,pm2会自动reload

2. 查看进程

# pm2list

# pm2 show 0 或者# pm2 info 0  #查看进程详细信息,0为PM2进程id

3. 监控

# pm2 monit

4. 停止

# pm2 stop all  #停止PM2列表中所有的进程

# pm2 stop 0    #停止PM2列表中进程为0的进程

5. 重载

# pm2 reload all    #重载PM2列表中所有的进程

# pm2 reload 0     #重载PM2列表中进程为0的进程

6. 重启

# pm2 restart all     #重启PM2列表中所有的进程

# pm2 restart 0      #重启PM2列表中进程为0的进程

7. 删除PM2进程

# pm2 delete 0     #删除PM2列表中进程为0的进程

# pm2 delete all   #删除PM2列表中所有的进程

8. 日志操作

# pm2 logs [--raw]   #Display all processes logs in streaming

# pm2 flush              #Empty all log file

# pm2 reloadLogs    #Reload all logs

9. 升级PM2

# npm install pm2@lastest -g   #安装最新的PM2版本

# pm2 updatePM2                    #升级pm2

10. 更多命令参数请查看帮助

# pm2 --help

四、PM2目录结构

默认的目录是:当前用于的家目录下的.pm2目录(此目录可以自定义,请参考:五、自定义启动文件),详细信息如下:

$HOME/.pm2#will contain all PM2 related files

$HOME/.pm2/logs#will contain all applications logs

$HOME/.pm2/pids#will contain all applications pids

$HOME/.pm2/pm2.log#PM2 logs

$HOME/.pm2/pm2.pid#PM2 pid

$HOME/.pm2/rpc.sock#Socket file for remote commands

$HOME/.pm2/pub.sock#Socket file for publishable events

$HOME/.pm2/conf.js#PM2 Configuration

五、自定义启动文件

创建一个test.json的示例文件,格式如下:

{

"apps":

{

"name": "test",

"cwd": "/data/wwwroot/nodejs",

"script": "./test.sh",

"exec_interpreter": "bash",

"min_uptime": "60s",

"max_restarts": 30,

"exec_mode" : "cluster_mode",

"error_file" : "./test-err.log",

"out_file": "./test-out.log",

"pid_file": "./test.pid"

"watch": false

}

}

说明:

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

name:应用程序的名称

cwd:应用程序所在的目录

script:应用程序的脚本路径

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

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

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

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

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

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

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

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

详细参数列表:见附件八

六、实例

已上面的test.json为例

# cat > /data/wwwroot/nodejs/test.sh << EOF

#!/bin/bash

while:

do

echo "Test" >> 1.log

sleep 5

done

EOF

# chmod +x test.sh      #添加执行权限

# pm2 start test.json    #启动,如下图:

# pm2 list    #查看pm2进程,如下图:

七、备注

其他可参数见官网:http://pm2.keymetrics.io

八、附件

FieldTypeExampleDescription

namestring"myAPI"name your app will have in PM2

scriptstring"bin/app.js"path of your app

argslist["--enable-logs", "-n", "15"]arguments given to your app when it is launched

node_argslist["--harmony", "--max-stack-size=1024"]arguments given to node when it is launched

cwdstring"/var/www/app/prod"the directory from which your app will be launched

exec_modestring"cluster""fork" mode is used by default, "cluster" mode can be configured with instances field

instancesnumber4number of instances for your clustered app, 0 means as much instances as you have CPU cores. a negative value means CPU cores - value (e.g -1 on a 4 cores machine will spawn 3 instances)

exec_interpreterstring"node"defaults to "node". can be "python", "ruby", "bash" or whatever interpreter you wish to use. "none" will execute your app as a binary executable

log_date_formatstring"YYYY-MM-DD HH:mm Z"format in which timestamps will be displayed in the logs

error_filestring"/var/log/node-app/node-app.stderr.log"path to the specified error log file. PM2 generates one by default if not specified and you can find it by typing pm2 desc

out_filestring"/var/log/node-app/node-app.stdout.log"path to the specified output log file. PM2 generates one by default if not specified and you can find it by typing pm2 desc

pid_filestring"pids/node-geo-api.pid"path to the specified pid file. PM2 generates one by default if not specified and you can find it by typing pm2 desc

merge_logsbooleanfalsedefaults to false. if true, it will merge logs from all instances of the same app into the same file

cron_restartstring"1 0 * * *"a cron pattern to restart your app. only works in "cluster" mode for now. soon to be avaible in "fork" mode as well

watchbooleantrueenables the watch feature, defaults to "false". if true, it will restart your app everytime a file change is detected on the folder or subfolder of your app.

ignore_watchlist["[\/\\]\./", "node_modules"]list of regex to ignore some file or folder names by the watch feature

min_uptimenumber1000min uptime of the app to be considered started (i.e. if the app crashes in this time frame, the app will only be restarted the number set in max_restarts (default 15), after that it's errored)

max_restartsnumber10number of consecutive unstable restarts (less than 1sec interval or custom time via min_uptime) before your app is considered errored and stop being

max_memory_restartstring"150M"your app will be restarted by PM2 if it exceeds the amount of memory specified. human-friendly format : it can be "10M", "100K", "2G" and so on...

envobject{"NODE_ENV": "production", "ID": "42"}env variables which will appear in your app

autorestartbooleanfalsetrue by default. if false, PM2 will not restart your app if it crashes or ends peacefully

vizionbooleanfalsetrue by default. if false, PM2 will start without vizion features (versioning control metadatas)

post_updatelist["npm install", "echo launching the app"]a list of commands which will be executed after you perform a Pull/Upgrade operation from Keymetrics dashboard

forcebooleantruedefaults to false. if true, you can start the same script several times which is usually not allowed by PM2

next_gen_jsbooleantruedefaults to false. if true, PM2 will launch your app using embedded BabelJS features which means you can run ES6/ES7 javascript code

restart_delaynumber4000time to wait before restarting a crashed app (in milliseconds). defaults to 0.


原文地址:https://blog.linuxeye.cn/435.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容