最可靠方式是用 find -mtime(非-ctime)按修改时间删除旧MySQL备份文件,因-mtime反映实际写入完成时间;需配合-type f、-name精确过滤,先-print测试再-delete,并在crontab中设置PATH和错误日志。用 find 按修改时间删旧备份文件最可靠Linux 下清理 MySQL 备份,find 是最轻量、最可控的选择。它不依赖数据库状态,也不需要额外服务,直接操作文件系统即可。关键不是"能不能删",而是"按什么时间维度删"------必须用 -mtime(修改时间)而非 -ctime(状态变更时间),因为备份脚本通常只改文件内容,不改权限或属主,-ctime 容易误判。-mtime +7 表示"7天前及更早修改的文件",注意:不是"超过7天",是">= 7*24小时",跨午夜计算,别按日历天数理解备份文件名带日期(如 backup_20240501.sql.gz)时,find 仍应优先看 -mtime,因为重命名、解压、传输都可能改变 -ctime 或 -atime,唯独 -mtime 反映实际写入完成时间务必先加 -print 测试,例如:find /backup/mysql -name "*.sql.gz" -mtime +7 -print,确认列出的确实是目标文件再加 -deleteMySQL 备份路径里混着临时文件?用 -type f 和 -name 组合过滤生产环境的备份目录常有 .tmp、.part、锁文件或日志,直接 find ... -delete 可能误删正在写的备份。安全做法是显式限定文件类型和命名模式。只删普通文件:find /backup/mysql -type f,排除目录、socket、设备节点限定扩展名组合:-name "*.sql.gz" -o -name "*.xbstream" -o -name "*.zst",避免匹配到 mysql-bin.000001 这类二进制日志(它们该由 expire_logs_days 管)如果备份脚本生成临时文件(如 backup_20240501.sql.gz.part),加 ! -name "*.part" 排除,否则 -mtime +7 可能把未完成的也删了保留最近 N 个备份?find 本身不支持"按数量留档",得配合 sort 和 tail按天备份但要求"永远留最近 14 个",仅靠 -mtime 不行------某天没备份,+14 就会多删;某天双备份,+14 又会少删。必须按文件名或时间戳排序后取尾部。 Zeemo AI 一款专业的视频字幕制作和视频处理工具
相关推荐
荣码4 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂金銀銅鐵14 小时前
[Python] 基于欧几里得算法,实现分数约分计算器Lyn_Li16 小时前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现小九九的爸爸21 小时前
前端想要入门Agent开发,要具备哪些Python基础?阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构jiayou641 天前
KingbaseES 表级与列级加密完全指南花酒锄作田2 天前
Pydantic校验配置文件hboot2 天前
AI工程师第四课 - 深度学习入门GBASE2 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器