华为云Windows Server服务器下,Node使用pm2-logrotate分割pm2日志,解决pm2日志内存占用过高的问题。

一、简介

  1. PM2 是一个守护进程管理器,它将帮助您管理和保持您的应用程序在线。
  2. PM2 入门很简单,它以简单直观的 CLI 形式提供,可通过 NPM 安装。
  3. 官网地址:https://pm2.keymetrics.io/

二、问题:pm2日志内存占用过高,且无法自动清理相关日志文件。

三、解决办法:使用pm2-logrotate分割pm2日志,解决pm2日志内存占用过高的问题。

pm2-logrotate 是一个pm2的插件,可以对pm2日志进行管理,所以它的运行需要依靠pm2。使用pm2-logrotate 解决pm2日志体积过大,进行分割。

  1. 手动删除日志
    两种办法
    (1)使用pm2命令手动删除:pm2 flush
    (2)找到pm2/logs文件夹,将文件夹内txt日志文件删除
  2. 安装
    注:该命令是 pm2 install不是 npm install
powershell 复制代码
pm2 install pm2-logrotate
  1. 查看配置指令
powershell 复制代码
pm2 conf pm2-logrotate
  1. 配置项
powershell 复制代码
// 每个文件最大存储   注:10G  10M  10K
pm2 set pm2-logrotate:max_size 50k

// retain:保留的日志文件个数,比如设置为30,那么在日志文件达到30个后就会将最早的日志文件删除
pm2 set pm2-logrotate:retain 30

// 是否通过gzip压缩日志
pm2 set pm2-logrotate:compress false

// dateFormat 日志文件名的日期格式。如设置的日志名为out.log,就会生成out-YYYY-MM-DD_HH-mm-ss.log 的日志文件
pm2 set pm2-logrotate:dateFormat YYYY-MM-DD_HH-mm-ss

// 检查日志大小的时间间隔,最小为1
pm2 set pm2-logrotate:workerInterval 30

// 设置强制分割,默认值是0 0 * * *,意思是每天晚上0点分割
pm2 set pm2-logrotate:rotateInterval 0 0 * * *
    
// rotateModule 是否把pm2本身的日志也进行分割    
pm2 set pm2-logrotate:rotateModule true
  1. 设置:自动删除pm2日志
powershell 复制代码
pm2 set pm2-logrotate:max_size 1M
pm2 set pm2-logrotate:retain 10

到此,就解决了pm2日志内存占用过高的问题。

本文原创,原创不易,如需转载,请联系作者授权。

相关推荐
还是奇怪1 小时前
Linux - 安全排查 2
linux·运维·安全
牛奶咖啡132 小时前
Linux系统的常用操作命令——文件远程传输、文件编辑、软件安装的四种方式
运维·服务器·软件安装·linux云计算·scp文件远程传输·vi文件编辑·设置yum的阿里云源
weixin_437398212 小时前
转Go学习笔记(2)进阶
服务器·笔记·后端·学习·架构·golang
难受啊马飞2.02 小时前
如何判断 AI 将优先自动化哪些任务?
运维·人工智能·ai·语言模型·程序员·大模型·大模型学习
会又不会2 小时前
Jenkins-Email Extension 插件插件
运维·jenkins
电脑能手3 小时前
[保姆级教程] 解决不同局域网电脑无法SSH的问题
运维·ssh·电脑
tan77º3 小时前
【Linux网络编程】Socket - UDP
linux·服务器·网络·c++·udp
czhc11400756633 小时前
Linux 76 rsync
linux·运维·python
szxinmai主板定制专家4 小时前
【精密测量】基于ARM+FPGA的多路光栅信号采集方案
服务器·arm开发·人工智能·嵌入式硬件·fpga开发
你不知道我是谁?4 小时前
负载均衡--四层、七层负载均衡的区别
运维·服务器·负载均衡