news 2026/4/22 17:08:12

用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/23 9:21:50

✅2026年小白必看的OpenClaw(Clawdbot)一键部署教程更新了!

Openclaw是什么?✅2026年小白必看的OpenClaw(Clawdbot)一键部署教程更新了!OpenClaw(原名Clawdbot/Moltbot)是一款开源的本地优先AI代理与自动化平台。它不仅能像聊天机器人一样对话,更能通过自然语言调用浏览器、文件…

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

硬碰硬!刚刚,Claude Opus 4.6与GPT-5.3-Codex同时发布

北京时间 2 月 6 日凌晨,Anthropic 与 OpenAI 相继推出了新版本基础大模型,分别是 Claude Opus 4.6 与 GPT-5.3-Codex。在春节来临之前,海外大模型先来了一波硬碰硬的发布。北京时间 2 月 6 日凌晨,Anthropic 与 OpenAI 相继推出了…

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

清单来了:10个降AI率工具测评对比,继续教育必备神器

在当前的学术写作环境中,AI生成内容(AIGC)已成为不可忽视的现象。无论是论文、报告还是课程作业,越来越多的内容由AI辅助完成,但随之而来的高AI率问题也引发了广泛关注。如何在保持原文语义和逻辑的同时,有…

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

TRCX应用:显示面板电容指纹分析

在大尺寸面板上扫描指纹是捕捉指纹上脊谷间的电容差异。为了加快计算执行速度,通过分布式计算对仿真区域进行划分,并自动合并为包含指纹信息的结果。工程师可以通过快速精确的仿真算法,根据布局结果分析电势分布和电容轮廓。分割模拟区域指纹…

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

程序员必藏:本地大模型部署全流程,从零开始轻松上手

本文是一篇面向初学者的实战指南,详细介绍了如何在个人电脑上搭建大模型环境。内容包括安装Python环境、使用uv项目管理工具、安装并运行Ollama本地大模型。通过这些步骤,即使是零基础的读者也能成功运行小型大模型(如gemma:1b)并…

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

新手也能上手!AI论文软件 千笔AI VS 万方智搜AI,本科生专属利器!

随着人工智能技术的迅猛发展,AI辅助写作工具已逐渐成为高校学生完成毕业论文的重要帮手。从开题报告到文献综述,从大纲构建到内容撰写,越来越多的学生开始借助AI工具提升写作效率、降低学术压力。然而,在众多功能各异的AI写作平台…

作者头像 李华