pm2 管理nodejs 日志存放问题
来源:互联网 发布:mysql数据库设计 编辑:程序博客网 时间:2024/05/19 02:31
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
这里可以自定义启动文件
[root@moppotest node]# cat push-web.json { "apps": { "name": "push-web", "cwd": "/root/node/node/", "script":"./push-web/app.js", "exec_interpreter": "bash", "min_uptime": "60s", "max_restarts": 30, "exec_mode" : "cluster_mode", "error_file" : "./logs/push-web-err.log", "out_file": "./logs/push-web-out.log", "pid_file": "./logs/push-web.pid" //这里的logs目录为/root/node/node/logs }}apps:json结构,apps是一个数组,每一个数组成员就是对应一个pm2中运行的应用name:应用程序的名称cwd:应用程序所在的目录script:应用程序的脚本路径exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejsmin_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是forkerror_file:自定义应用程序的错误日志文件out_file:自定义应用程序日志文件pid_file:自定义应用程序的pid文件watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。
每个配置完成,为了方便管理和启动,编写如下脚本
#!/bin/bashecho -e '''\033[0;32mPlease choice your action:[1]start[2]stop[3]restart\033[0m'''echo "========================"read NUMif [ $NUM == 1 ] then STATUS=startelif [ $NUM == 2 ] then STATUS=stopelse STATUS=restartfipm2 $STATUS /root/node/node/push-install.jsonpm2 $STATUS /root/node/node/push-web.jsonpm2 $STATUS /root/node/node/app-web.jsonpm2 $STATUS /root/node/node/app-ubc.jsonecho -e "\033[0;31m=====Now show you node status========\033[0m"sleep 5pm2 list
这里附上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会自动reload2. 查看进程# pm2 list# 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 logs9. 升级PM2# npm install pm2@lastest -g #安装最新的PM2版本# pm2 updatePM2 #升级pm210. 更多命令参数请查看帮助# pm2 --help
参考链接:https://www.npmjs.com/package/pm2
0 0
- pm2 管理nodejs 日志存放问题
- pm2管理nodejs服务
- PM2管理nodejs
- pm2管理nodejs进程
- Nodejs管理工具PM2问题记录
- nodejs+pm2
- Hadoop日志存放问题
- NodeJS日志管理 Log4js
- nodejs pm2教程
- 使用pm2部署nodejs
- pm2部署nodejs项目
- PM2部署nodejs项目
- nodejs启动守护程序pm2
- nodejs pm2的简单应用
- nodejs pm2配置使用教程
- linux安装nodejs、cnpm、pm2
- 使用pm2启动nodeJS程序
- hadoop提交任务后日志存放问题
- React入门记事本小项目(三)
- 精通 CSS+DIV 网页样式与布局 80
- 神经网络(二)
- 【每日一记】设计模式——建造者模式
- ZCMU—1774
- pm2 管理nodejs 日志存放问题
- Oracle materizlized view Study
- 关于dispose 方法的资源释放
- 多线程中的Join()方法
- LeetCode #231 - Power of Two - Easy
- 架构设计的原则
- UML关系和图解析
- Apache与Nginx的优缺点比较
- error: could not install *smartsocket* listener: cannot bind to 127.0.0.1:5037: 通常每个套接字地址。。。