news 2026/4/18 7:04:45

用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/4/3 12:51:41

【Unity】【Photon】Fusion2中的延迟补偿机制(Lag Compensation)学习笔记

介绍 只有服务器模式和主机模式提供延迟补偿机制。 在共享模式中,每个客户端都有权限并决定其击中的目标。这种方式精准,但容易被作弊所利用。 对于客户端服务器游戏而言,延迟补偿解决了快节奏多人游戏中的一个根本问题:即便无法完全信任客户端,也能让其获得所见即所得(…

作者头像 李华
网站建设 2026/4/17 23:13:10

【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/3/29 5:05:15

java+vue基于springboot的家庭医生预约服务软件设计_7mr4t5lr

目录技术栈与框架核心功能模块系统架构特点数据处理与安全部署与扩展性开发技术源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!技术栈与框架 基于SpringBoot的后端框架提供RESTful API,采用Java语言开发,确保高…

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

31.Android系统源码-ICU实战 - 国际化组件核心技术

ICU实战 - 国际化组件核心技术 目录 一、核心技术概览 二、Unicode字符处理 2.1 字符属性查询系统 2.2 Unicode规范化引擎 2.3 大小写转换实现 三、文本排序Collation引擎

作者头像 李华