0

0

Linux日志怎么切割_Linux日志通过logrotate按CPU使用率切割的实用方法

爱谁谁

爱谁谁

发布时间:2025-11-17 22:40:02

|

469人浏览过

|

来源于php中文网

原创

logrotate不支持按CPU使用率直接切割日志,但可通过监控脚本在CPU过高时触发日志轮转。1. logrotate默认按时间或大小切割日志;2. 编写脚本监控指定进程CPU使用率,超过阈值则调用logrotate强制轮转;3. 结合crontab定期执行脚本;4. 配置logrotate使用size、copytruncate等参数优化高负载场景下的日志管理,实现高效故障排查。

linux日志怎么切割_linux日志通过logrotate按cpu使用率切割的实用方法

Linux系统中日志文件会随着时间不断增长,影响系统性能和磁盘空间。logrotate 是 Linux 下管理日志文件的标准工具,通常按时间或大小进行切割,但默认并不支持按 CPU 使用率直接切割日志——因为日志本身不反映进程的 CPU 消耗。不过,可以通过结合监控脚本与 logrotate 的机制,实现“在高 CPU 场景下触发日志行为”的实用策略。

理解 logrotate 的基本机制

logrotate 通过配置文件定义日志的轮转规则,常见触发条件包括:

  • 按天、周、月周期(daily, weekly, monthly)
  • 当日志文件达到指定大小(size)
  • 手动执行 logrotate -f config_file

它不直接监听 CPU 使用情况,但可以被外部脚本调用。这意味着我们能通过监控 CPU 来决定是否强制轮转日志。

通过监控脚本触发日志切割

虽然不能直接“按 CPU 使用率切割日志”,但可以在检测到高 CPU 时主动调用 logrotate,保留关键时间段的日志以便分析。

例如:当某个服务进程 CPU 占用过高时,自动切割其日志,便于事后排查问题。

编写一个简单的监控脚本(如 monitor_cpu_and_rotate.sh):

Rytr写作助手
Rytr写作助手

Rytr 是一款AI内容生成和写作助手,可帮助您在短短几秒钟内以极低的成本创建高质量的内容!

下载
#!/bin/bash
PROCESS_NAME="your_service" # 替换为实际进程名
LOGROTATE_CONF="/etc/logrotate.d/your_app"
THRESHOLD=80 # CPU 使用率阈值(%)

PID=$(pgrep $PROCESS_NAME)
if [ -z "$PID" ]; then
  exit 0
fi

# 获取该进程的 CPU 使用率(采样一次)
CPU_USAGE=$(ps -p $PID -o %cpu --no-headers | awk '{print $1}' | cut -d. -f1)

if [ "$CPU_USAGE" -gt "$THRESHOLD" ]; then
  # 触发日志切割
  /usr/sbin/logrotate -f $LOGROTATE_CONF
  echo "$(date): High CPU detected ($CPU_USAGE%), log rotated." >> /var/log/cpu_monitor.log
fi

将此脚本加入 crontab 定期执行:

* * * * * /path/to/monitor_cpu_and_rotate.sh

优化日志策略配合高负载场景

除了被动响应,还可提前设计日志策略应对高负载:

  • 使用 size 参数让 logrotate 在日志增长过快时自动切割
  • 启用 copytruncate 避免服务重启,适合无法重读日志句柄的程序
  • 结合 systemd-journald 限制内存中日志大小,防止突发日志撑爆磁盘

示例配置(/etc/logrotate.d/your_app):

/var/log/your_app.log {
  size 100M
  copytruncate
  compress
  missingok
  notifempty
}

这样即使没有 CPU 直接触发,也能在高负载导致日志激增时自动处理。

基本上就这些。logrotate 本身不支持按 CPU 切割,但通过外部监控 + 脚本调用,完全可以实现“高 CPU 时保留现场日志”的实用目标,提升故障排查效率。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.09.27

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

731

2023.08.22

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1347

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

700

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

545

2023.07.20

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

3

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7万人学习

Git 教程
Git 教程

共21课时 | 2.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号