贝利信息

如何配置mysql日志保留策略_mysql日志保留设置说明

日期:2026-01-05 00:00 / 作者:P粉602998670
MySQL日志保留策略通过配置binlog、error log、slow log和general log的自动清理机制实现,核心是设置过期时间或大小上限;binlog推荐用binlog_expire_logs_seconds(8.0.23+)或expire_logs_days(旧版)控制天数,error log依赖logrotate轮转并发送USR1信号,slow log和general log建议按需开启并定期归档,同时需监控日志大小防磁盘占满。

MySQL 日志保留策略主要通过配置二进制日志(binlog)、错误日志(error log)、慢查询日志(slow query log)和通用查询日志(general log)的自动清理机制来实现。核心控制方式是设置过期时间或文件大小上限,避免磁盘被日志占满。

二进制日志(binlog)保留天数控制

binlog 是主从复制和数据恢复的关键,但长期积累会占用大量空间。推荐用 expire_logs_days 参数设定自动删除天数(MySQL 8.0.23 起已弃用,建议改用 binlog_expire_logs_seconds)。

错误日志(error log)轮转与截断

MySQL 自身不直接管理 error log 的轮转,需依赖外部工具或操作系统机制。

慢查询日志与通用查询日志的开关与归档

这两类日志 I/O 开销大,生产环境建议按需开启,并配合定期归档清理。

验证与监控日志清理效果

配置生效后,需定期检查实际保留情况,防止策略失效。