news 2026/5/1 8:39:50

用Linux脚本轮转业务系统的日志

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
用Linux脚本轮转业务系统的日志

背景

上一篇文章用Linux自带的logrotate来轮转日志,确实方便,但它会改变当前日志文件的指针,因为它的机制是重新创建当前日志文件。在有些情况下,会出现奇怪的问题。比如一直打开当前日志文件不关闭的业务系统会受影响。

解决

自己写Linux脚本来轮转日志,最大的区别是:不会重新创建当前日志,而是收缩或清空当前日志。

轮转

#!/bin/bash# 日志轮转脚本 - rotate_log.sh# 使用方法:可以放在crontab中,每天00:01执行# crontab设置示例:1 0 * * * /path/to/rotate_log.sh# 设置日志目录 - 请根据实际情况修改LOG_DIR="/myapp/log"CURRENT_LOG="$LOG_DIR/current.log"# 检查日志目录是否存在if[!-d"$LOG_DIR"];thenecho"错误:日志目录不存在 -$LOG_DIR"exit1fi# 检查当前日志文件是否存在if[!-f"$CURRENT_LOG"];thenecho"警告:当前日志文件不存在 -$CURRENT_LOG"exit0# 这不是致命错误,只是没有日志需要轮转fi# 获取前一天的日期(格式:YYYY-MM-DD)# 注意:macOS和Linux的date命令参数可能不同,这里使用通用格式YESTERDAY=$(date-d"yesterday"+"%Y-%m-%d"2>/dev/null||date-v-1d +"%Y-%m-%d"2>/dev/null)if[-z"$YESTERDAY"];thenecho"错误:无法获取昨天的日期"exit1fi# 备份文件名BACKUP_LOG="$LOG_DIR/$YESTERDAY.log"# 检查备份文件是否已存在if[-f"$BACKUP_LOG"];thenecho"警告:备份文件已存在,跳过轮转 -$BACKUP_LOG"exit0fi# 复制当前日志到备份文件ifcp"$CURRENT_LOG""$BACKUP_LOG";thenecho"已复制日志到:$BACKUP_LOG"# 清空当前日志文件iftruncate -s0"$CURRENT_LOG";thenecho"已清空当前日志文件:$CURRENT_LOG"else# 如果truncate命令不可用,使用其他方法>"$CURRENT_LOG"&&echo"已清空当前日志文件:$CURRENT_LOG"fi# 可选:压缩备份文件以节省空间# gzip "$BACKUP_LOG" && echo "已压缩备份文件: $BACKUP_LOG.gz"echo"日志轮转完成于:$(date)"exit0elseecho"错误:无法复制日志文件"exit1fi

清理旧日志

#!/bin/bash# 日志清理脚本 - clean_old_logs.sh# 删除超过7天的日志文件# crontab设置示例:0 2 * * * /path/to/clean_old_logs.sh# 设置日志目录 - 请根据实际情况修改LOG_DIR="/myapp/log"# 设置保留天数DAYS_TO_KEEP=7# 检查日志目录是否存在if[!-d"$LOG_DIR"];thenecho"错误:日志目录不存在 -$LOG_DIR"exit1fi# 切换到日志目录cd"$LOG_DIR"||{echo"错误:无法进入日志目录 -$LOG_DIR"exit1}# 查找并删除超过7天的.log文件# 注意:这里使用find命令的-mtime参数,它会根据文件的修改时间来判断# +7 表示7天以前的文件# -name "*.log" 表示匹配.log文件echo"开始清理超过$DAYS_TO_KEEP天的日志文件..."# 先列出将要删除的文件(用于检查)# echo "将要删除的日志文件:"# find . -maxdepth 1 -name "*.log" -type f -mtime +$DAYS_TO_KEEP -print# # 询问是否确认删除(如果是手动执行)# # 如果是crontab自动执行,可以移除交互部分# if [ -t 0 ]; then# # 在终端中运行,询问确认# read -p "是否确认删除这些文件?(y/N): " -n 1 -r# echo# if [[ ! $REPLY =~ ^[Yy]$ ]]; then# echo "取消操作"# exit 0# fi# fi# 实际执行删除操作DELETED_COUNT=$(find.-maxdepth1-name"*.log"-type f -mtime +$DAYS_TO_KEEP -delete -print|wc-l)echo"已删除$DELETED_COUNT个过期日志文件"echo"清理完成于:$(date)"# 可选:同时清理压缩的日志文件(如果使用了压缩)# find . -maxdepth 1 -name "*.log.gz" -type f -mtime +$DAYS_TO_KEEP -delete# echo "已清理压缩的日志文件"

定时执行

sudocrontab-e00* * * /myapp/logrotate/rotate_log.sh04* * * /myapp/logrotate/clean_old_logs.sh
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 7:19:39

全网最全中望CAD二次开发教程-ZRX

中望CAD是国产CAD的领军之作,在信创背景下,大有可为。掌握中望CAD二次开发技术,不仅能深度契合特定业务场景、快速定制高效插件,更是提升行业竞争力的关键。下面推荐的专栏,专注于ZWCAD二开,从零基础出发&a…

作者头像 李华
网站建设 2026/4/9 16:53:21

Agent Skills 笔记

更多的是在工程概念上的革新,而不是功能上的革新。 Agent Skills 规范是 Anthropic 在 Claude Code 落地的标准化概念(2025-10),目前作为跨平台开放标准(2025-12)。 可迁移:通用标准规范&#…

作者头像 李华
网站建设 2026/4/23 7:53:02

java+vue基于springboot的户外救援系统_jdzgi247

目录 户外救援系统概述技术架构核心功能模块系统特点部署与维护 开发技术源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式! 户外救援系统概述 基于SpringBoot和Vue的户外救援系统是一个结合后端Java技术和前端Vue框架的综合性解决方案&a…

作者头像 李华
网站建设 2026/4/18 23:51:34

工业AI平台不是工具,而是企业的新生产力——该怎么理解?

在制造业的转型浪潮中,“工业AI”这个词早已不新鲜。但真正让人困惑的,不是它有多先进,而是为什么那么多企业投入重金,却依然看不到实质性的效率提升。问题的根源,往往不在于算法不够复杂,而在于平台本身是…

作者头像 李华
网站建设 2026/5/1 7:23:44

【课程设计/毕业设计】基于Django框架的多媒体资料管理系统基于python的媒体资源管理系统设计与实现【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华