Linux服务器使用Cron实现日志自动清理方案

 更新时间:2026年01月19日 08:34:04   作者:爱琴孩  
本文详细介绍了如何使用find和cron组合实现Linux服务器日志的自动化清理,包括日志目录分析、解决方案设计、实施步骤、验证与测试以及find命令的详细解析,需要的朋友可以参考下

一、背景问题

在生产环境中,随着服务持续运行,日志文件会不断累积,占用大量磁盘空间。以某开发测试服务器为例:

  • 日志目录/data/logs
  • 服务数量:100+ 个微服务
  • 磁盘占用:28G
  • 待清理文件:24267 个(超过 7 天)

如果不及时清理,可能导致磁盘空间不足,影响服务正常运行。

二、日志目录分析

2.1 目录结构

/data/logs/
├── cas_logs/                    # CAS认证服务日志
├── nginx/                       # Nginx日志
├── ttpt_cas/                    # 平台CAS日志
├── yyzx_testservice_logs/       # 测试服务日志
├── ... (100+ 服务目录)
├── spring.log                   # 散落的日志文件
└── spring.log.2025-12-31.log

2.2 日志文件命名规则

通过分析,发现日志文件主要有以下几种命名格式:

格式示例
服务名-YYYY-MM-DD-HH-序号.logcas-2022-01-04-11-1.log
服务名.log.YYYY-MM-DD.logttpt_gmservice_logs.log.2026-01-08.log
access_log.YYYY-MM-DD.logaccess_log.2026-01-08.log
*.gz压缩后的历史日志

三、解决方案设计

3.1 技术方案

使用 find + cron 组合实现自动化日志清理:

  • find 命令:按文件类型和修改时间筛选日志文件
  • cron 定时任务:每天定时执行清理脚本
  • 日志记录:记录每次清理操作,便于追溯

3.2 安全措施

安全措施说明
目录限制只在 /data/logs 目录下操作
文件类型限制只删除 *.log*.log.**.gz 文件
只删文件使用 -type f,不删除目录
时间限制只删除 7 天前的文件(-mtime +7
操作日志记录每次清理的时间和文件数量

四、实施步骤

4.1 创建脚本目录

mkdir -p /data/scripts

4.2 创建清理脚本

创建文件 /data/scripts/clean_old_logs.sh

#!/bin/bash
#
# 日志清理脚本 - 删除7天前的日志文件
# 每天早上9点由cron定时执行
# 
# 安全措施:
# 1. 只在 /data/logs 目录下操作
# 2. 只删除日志文件(*.log, *.log.*, *.gz)
# 3. 只删除文件,不删除目录
# 4. 记录清理日志
#
​
LOG_DIR="/data/logs"
DAYS=7
SCRIPT_LOG="/data/scripts/clean_logs_history.log"
​
# 确保只在 /data/logs 目录下操作
if [ ! -d "$LOG_DIR" ]; then
    echo "$(date '+%Y-%m-%d %H:%M:%S') - 错误: 目录 $LOG_DIR 不存在" >> "$SCRIPT_LOG"
    exit 1
fi
​
# 记录开始时间
echo "$(date '+%Y-%m-%d %H:%M:%S') - 开始清理 ${DAYS} 天前的日志文件..." >> "$SCRIPT_LOG"
​
# 统计将要删除的文件数量
COUNT=$(find "$LOG_DIR" -type f \( -name "*.log" -o -name "*.log.*" -o -name "*.gz" \) -mtime +$DAYS 2>/dev/null | wc -l)
​
# 删除日志文件
find "$LOG_DIR" -type f \( -name "*.log" -o -name "*.log.*" -o -name "*.gz" \) -mtime +$DAYS -delete 2>/dev/null
​
# 记录完成
echo "$(date '+%Y-%m-%d %H:%M:%S') - 清理完成,共删除 $COUNT 个文件" >> "$SCRIPT_LOG"

4.3 赋予执行权限

chmod +x /data/scripts/clean_old_logs.sh

4.4 配置 Cron 定时任务

# 添加定时任务(每天早上9点执行)
(crontab -l 2>/dev/null | grep -v "clean_old_logs.sh"; echo "0 9 * * * /bin/bash /data/scripts/clean_old_logs.sh") | crontab -
​
# 验证是否添加成功
crontab -l

Cron 表达式说明

0 9 * * * /bin/bash /data/scripts/clean_old_logs.sh
│ │ │ │ │
│ │ │ │ └── 星期几 (0-7, 0和7都表示周日)
│ │ │ └──── 月份 (1-12)
│ │ └────── 日期 (1-31)
│ └──────── 小时 (0-23)
└────────── 分钟 (0-59)

五、验证与测试

5.1 预览待删除文件

# 查看将被删除的文件数量
find /data/logs -type f \( -name "*.log" -o -name "*.log.*" -o -name "*.gz" \) -mtime +7 2>/dev/null | wc -l
​
# 查看部分文件列表
find /data/logs -type f \( -name "*.log" -o -name "*.log.*" -o -name "*.gz" \) -mtime +7 2>/dev/null | head -20

5.2 手动执行测试

# 执行清理脚本
/bin/bash /data/scripts/clean_old_logs.sh
​
# 查看清理记录
cat /data/scripts/clean_logs_history.log
​
# 查看磁盘使用变化
du -sh /data/logs

5.3 查看 Cron 执行日志

# 查看系统 cron 日志
tail -f /var/log/cron
​
# 查看清理历史记录
cat /data/scripts/clean_logs_history.log

六、find 命令详解

6.1 核心参数说明

参数说明
-type f只匹配文件,不匹配目录
-name "*.log"匹配文件名模式
-o逻辑或,连接多个匹配条件
-mtime +7修改时间超过 7 天
-delete删除匹配的文件
2>/dev/null忽略权限不足等错误信息

6.2 时间参数对比

参数含义
-mtime +7修改时间 > 7 天前
-mtime 7修改时间 = 7 天前
-mtime -7修改时间 < 7 天前(7 天内)
-atime访问时间
-ctime状态改变时间

七、排除或指定目录清理

7.1 如何排除某些目录不清理?

在 find 命令中添加 -not -path 参数:

find "$LOG_DIR" -type f \
    -not -path "*/kafka-logs/*" \
    -not -path "*/nginx/*" \
    \( -name "*.log" -o -name "*.log.*" -o -name "*.gz" \) \
    -mtime +$DAYS -delete

7.2 如何只清理特定服务的日志?

修改 LOG_DIR 或添加路径过滤:

# 只清理特定服务
LOG_DIR="/data/logs/yyzx_testservice_logs"
​
# 或使用通配符匹配多个服务
find /data/logs/yyzx_* -type f -name "*.log" -mtime +7 -delete

八、总结

本方案通过 find + cron 实现了服务器日志的自动化清理:

项目配置
清理目录/data/logs
保留天数7 天
执行时间每天 09:00
清理记录/data/scripts/clean_logs_history.log

核心优势

  • ✅ 自动化执行,无需人工干预
  • ✅ 安全限制,避免误删重要文件
  • ✅ 操作留痕,便于问题追溯
  • ✅ 配置灵活,易于调整参数

以上就是Linux服务器使用Cron实现日志自动清理方案的详细内容,更多关于Linux Cron日志自动清理的资料请关注脚本之家其它相关文章!

相关文章

  • Linux系统中创建SSH服务器别名的两种方法

    Linux系统中创建SSH服务器别名的两种方法

    这篇文章主要给大家介绍了关于Linux系统中创建SSH服务器别名的两种方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Linux系统具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • Linux中crontab定时任务不执行的原因

    Linux中crontab定时任务不执行的原因

    本篇文章主要介绍了Linux中crontab定时任务不执行的原因,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • centos 7 安装卸载apache(httpd)服务的详细步骤

    centos 7 安装卸载apache(httpd)服务的详细步骤

    前面我们已经安装好了mysql,今天安装httpd,然后试着访问以下,由于博主已经安装过一次,所以先说卸载,再说安装,需要的朋友可以参考下
    2020-07-07
  • Ubuntu16.04搭建NFS 文件共享服务器的方法

    Ubuntu16.04搭建NFS 文件共享服务器的方法

    这篇文章主要介绍了Ubuntu16.04搭建NFS 文件共享服务器的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • Linux 下安装pip包的方法

    Linux 下安装pip包的方法

    这篇文章主要介绍了Linux 下安装pip包的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • Linux服务器数据盘移除并重新挂载的全过程

    Linux服务器数据盘移除并重新挂载的全过程

    这篇文章主要介绍了在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保数据安全和系统稳定性,需要的朋友可以参考下
    2025-11-11
  • 在Linux中如何查看服务器整体情况

    在Linux中如何查看服务器整体情况

    这篇文章主要介绍了在Linux中如何查看服务器整体情况问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 解决虚拟机NAT模式无法上网问题

    解决虚拟机NAT模式无法上网问题

    文章主要介绍了确认虚拟机网络连接问题的两个步骤:首先检查虚拟机的IP地址是否与主机在同一网段,其次确保虚拟机相关服务已开启
    2024-12-12
  • Apache 多端口多站点配置方法

    Apache 多端口多站点配置方法

    Apache多端口多站点的配置方法,配置apache服务器的朋友可以参考下。
    2010-08-08
  • ubuntu系统下禁用utc时间的设置方法

    ubuntu系统下禁用utc时间的设置方法

    这篇文章主要给大家介绍了在ubuntu系统下禁用utc时间的设置方法,需要的朋友可以参考下
    2017-05-05

最新评论