使用pm2常见问题
一、日志
1、pm2 的log怎么查看?(安装pm2后默认日志的路径为~/.pm2/),可以通过pm2 show (name)来查看某个进程下的日志地址
2、修改日志的输出路径,通过写一个程序启动的配置文件apps.yml,在里面可以设置日志的输出地址,输出文件,已经输出的格式。例如:
apps:
- script : ./app.js
name : 'loginServer'
instances: 2
cwd: /var/service/ACServer/LoginServer
max_memory_restart: 1G // 内存超过1G之后自动重启
exec_mode: cluster
#log_date_format: "YYY-MM-DD HH:mZ" // 配置日志的输出格式
#error_file: "/var/data/loginLogs/pm2logs/loginErr.log" 配置out日志的输出文件名
#out_file: "/var/data/loginLogs/pm2logs/loginOut.log"
3、清楚(pm2 flush)与重载日志(pm2 reloadLogs
)
二、开机自启 nodejs 服务器
启动想开机启动的项目 pm2 start app.js
保存 pm2 save
开机设置 pm2 startup centos
chmod +x /etc/init.d/pm2-init.sh
chkconfig –add pm2-init.sh
三、pm2-logrotate进行日志分割
使用pm2-logrotate进行日志管理使得我们的node服务的log以及pm2的log能够得到控制,防止log过多导致把磁盘刷爆。pm2-logrotate配置看官网,需要注意的是设置retain参数,来限制日志文件数
pm2 set pm2-logrotate:retain 10
四、pm2 monit命令监控你的内存和CPU
五、异常问题
今天在跑程序的时候pm2 突然报如下错误:
C:\server\MobileServer>pm2 start apps.yml
[PM2][WARN] Applications MobileAPI, MobileMapReduce not running, starting...
C:\Users\Administrator\AppData\Roaming\npm\node_modules\pm2\lib\API.js:1031
intOut(conf.PREFIX_MSG + 'App [%s] launched (%d instances)', data[0].pm2_env.n
^
TypeError: Cannot read property 'pm2_env' of undefined
at C:\Users\Administrator\AppData\Roaming\npm\node_modules\pm2\lib\API.js:1031:86
at C:\Users\Administrator\AppData\Roaming\npm\node_modules\pm2\node_modules\pm2-axon-rpc\lib\client.js:45:10
at Parser.<anonymous> (C:\Users\Administrator\AppData\Roaming\npm\node_modules\pm2\node_modules\pm2-axon\lib\sockets\req.js:67:8)
at Parser.emit (events.js:107:17)
at Parser._write (C:\Users\Administrator\AppData\Roaming\npm\node_modules\pm2\node_modules\pm2-axon\node_modules\amp\lib\stream.js:91:16)
at doWrite (_stream_writable.js:301:12)
at writeOrBuffer (_stream_writable.js:288:5)
at Parser.Writable.write (_stream_writable.js:217:11)
at Socket.ondata (_stream_readable.js:540:20)
at Socket.emit (events.js:107:17)
按照报错信息应该是:pm2 环境设置问题。
通过pm2 在github上的issue找到了解决方案,地址如下:
https://github.com/Unitech/pm2/issues/2154
只需要运行下:pm2 update
然后重启服务就可以了。
六、log4js中关于pm2的设置
在pm2zhongoing使用log4js需要对log4js的配置文件进行设置,这里主要参见官方文档:https://log4js-node.github.io/log4js-node/api.html
具体demo配置如:
const logConfig = appenders: {
console: {
type: 'console'
},
file: {
type: 'file',
filename: './logs/application.log',
maxLogSize: 104800,
backups: 100
},
date_file: {
type: 'dateFile',
filename: "./logs/date",
alwaysIncludePattern: true,
pattern: "-yyyy-MM-dd.log"
}
},
categories: {
default: {appenders: ['console'], level: 'info'},
errorLog: {appenders: ['console', 'file', 'date_file'], level: 'error'}
},
// 关于pm2的设置
pm2: true,
disableClustering: true
}; module.exports = logConfig;
前不久在测试服上开启一个进程的时候没加disableClustering参数,后来开启多进程之后发现只有第一个进程能看到正常的log4js的log,而其他进程则没有,回来阅读api,设置disableClustering:true。这样
每个进程的log就出现了。
七、是否需要nginx
nginx可以做的事情主要有两个:
1、反向代理,实现简单的负载均衡: 如果有多台服务器或者一台服务器多个端口,可以考虑用nginx。 2、静态资源缓存:把一些静态资源(如静态页面,js等资源文件)放到nginx里,可以极大的提高服务的性能。
参考:https://github.com/jawil/blog/issues/7/
使用pm2常见问题的更多相关文章
- Nuxt.js的踩坑指南(常见问题汇总)
本文会不定期更新在nuxt.js中遇到的问题进行汇总.转发请注明出处,尊重作者,谢谢! 强烈推荐作者文档版踩坑指南,点击跳转踩坑指南 在Nuxt的官方文档中,中文文档和英文文档都存在着不小的差异. 1 ...
- NodeJs之pm2
pm2 pm2是一个进程管理工具,可以用它来管理你的node进程,并查看node进程的状态,当然也支持性能监控,进程守护,负载均衡等功能. 开发过程中建议时不时的参看官方详细命令行使用:命令行 pm2 ...
- C++常见笔试面试要点以及常见问题
1. C++常见笔试面试要点: C++语言相关: (1) 虚函数(多态)的内部实现 (2) 智能指针用过哪些?shared_ptr和unique_ptr用的时候需要注意什么?shared_ptr的实现 ...
- Node.js使用PM2的集群将变得更加容易
介绍 众所周知,Node.js运行在Chrome的JavaScript运行时平台上,我们把该平台优雅地称之为V8引擎.不论是V8引擎,还是之后的Node.js,都是以单线程的方式运行的,因此,在多核心 ...
- 自建git node pm2 (不赘述,就说遇见的问题)
//======================[git]部分 主题部分还是按照网上的办法进行安装. 安装的话 分为两个办法(一个是yum (contos办法) 或者sudo(ubuntu办法) ...
- SQL Server常见问题介绍及快速解决建议
前言 本文旨在帮助SQL Server数据库的使用人员了解常见的问题,及快速解决这些问题.这些问题是数据库的常规管理问题,对于很多对数据库没有深入了解的朋友提供一个大概的常见问题框架. 下面一些问题是 ...
- 【腾讯优测干货分享】如何降低App的待机内存(二)——规范测试流程及常见问题
本文来自于腾讯优测公众号(wxutest),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq.com/s/806TiugiSJvFI7fH6eVA5w 作者:腾讯TMQ专项测 ...
- mysql数据库开发常见问题及优化
mysql 数据库是被广泛应用的关系型数据库,其体积小.支持多处理器.开源并免费的特性使其在 Internet 中小型网站中的使用率尤其高.在使用 mysql 的过程中不规范的 SQL 编写.非最优的 ...
- 《PDF.NE数据框架常见问题及解决方案-初》
<PDF.NE数据框架常见问题及解决方案-初> 1.新增数据库后,获取标识列的值: 解决方案: PDF.NET数据框架,已经为我们考略了很多,因为用PDF.NET进行数据的添加操作时 ...
随机推荐
- ssh事务配置
<!-- 配置业务层 --> <bean id="employeeService" class="cn.bdqn.jboa.service.impl.E ...
- Spark Graphx In Action
两个重要的技术:Spark和graphs 本章节内容 为什么Spark是最先进的大数据处理系统 是什么让图可以以一种独特的方式来模拟关联数据 GraphX为什么会成规领先的图分析平台
- Socket 学习入门
http://www.codeproject.com/Articles/13071/Programming-Windows-TCP-Sockets-in-C-for-the-Begin
- l来自wentao:项目加入缓存(redis),实时调试时用 -----可视化缓存,flushdb
下文来自segmentfault,网站:一个交流网站:https://segmentfault.com/ 在做一个项目时如果加入缓存(例如redis),我如何进行实时调试呢? 缓存 高并发 架构 gz ...
- Linux下远程cp命令scp
2014-2.19 PS1.在用此命令cpLinux与Linux之间的数据时发现有些服务器上默认没有安装scp但用yum -y install scp提示么有这样的包 后来发现原来scp工具的安装包 ...
- Android软键盘隐藏,遮挡EidtText解决办法
一.自动弹出软键盘 Timer timer=new Timer(); timer.schedule(new TimerTask() { public void run() { InputMethodM ...
- UVa 11464 - Even Parity
解题报告:题目大意有一个N×N的矩阵,矩阵中的元素只有1或0,如果说对于一个矩阵,它的所有的点的上下左右的点的和是偶数,则称这个矩阵为偶数矩阵,现在给你一个任意的矩阵,要求的是如果要把这个矩阵变成偶数 ...
- [Effective JavaScript 笔记]第59条:避免过度的强制转换
js是弱类型语言.许多标准的操作符和代码库会把输入参数强制转换为期望的类型而不是抛出错误.如果未提供额外的逻辑,使用内置操作符的程序会继承这样的强制转换行为. functin square(x){ r ...
- 纯Java获得本地MAC地址
import java.net.*; public class Ipconfig{ public static void main(String[] arguments) throws Ex ...
- Shell脚本中cd命令使用
在写shell脚本的时候发现cd切换目录的时候无法切换,代码是下面的. #!/bin/bash #changedir.sh history cd /home/firefox sleep pwd 我仔细 ...