华为云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日志内存占用过高的问题。

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

相关推荐
代码游侠2 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
主机哥哥2 小时前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
Harvey9032 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
珠海西格电力科技3 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市
释怀不想释怀3 小时前
Linux环境变量
linux·运维·服务器
zzzsde3 小时前
【Linux】进程(4):进程优先级&&调度队列
linux·运维·服务器
qq_297574674 小时前
Linux 服务器 Java 开发环境搭建保姆级教程
java·linux·服务器
聆风吟º5 小时前
CANN开源项目实战指南:使用oam-tools构建自动化故障诊断与运维可观测性体系
运维·开源·自动化·cann
神梦流5 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
NPE~5 小时前
自动化工具Drissonpage 保姆级教程(含xpath语法)
运维·后端·爬虫·自动化·网络爬虫·xpath·浏览器自动化