MySQL如何配置定时清理过期备份文件_find命令与保留周期策略

最可靠方式是用 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 一款专业的视频字幕制作和视频处理工具

相关推荐
cmes_love8 小时前
Level 2逐笔成交历史数据下载方法笔记
数据库·笔记·oracle
CTA终结者8 小时前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
马士兵教育8 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
swordbob8 小时前
MySQL字符集陷阱:从Oracle迁移踩坑到utf8mb4强制规范
数据库·sql
牛油果子哥q8 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
KaMeidebaby8 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
十五年专注C++开发9 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
Cloud_Shy6189 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
数据库小学妹9 小时前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai
天佑木枫9 小时前
15天Python入门系列 · 序
开发语言·python