MySQL日志保留策略:设置binlog日志保存天数、文件大小限制
一、设置binlog日志保存天数、文件大小限制
在MySQL中,有三种主要类型的日志记录:二进制日志(binlog)、错误日志和查询日志。这些日志记录对于MySQL数据库的管理和维护非常重要。在本文中,我们将重点讨论如何设置binlog日志的保留策略。
默认情况下,MySQL会自动将binlog日志文件保存在主目录或指定目录下,并且不限制binlog日志文件的大小和日志保留时间。这意味着当日志文件太大或当你不再需要它们时,你需要手动删除它们。
所以,为了优化MySQL数据库的管理,我们可以通过在MySQL配置文件my.cnf中添加以下内容来设置binlog日志的保留策略:
1 | [mysqld] |
以上配置将保留最近7天的binlog日志文件,并且每个binlog文件的最大大小为100M。当binlog日志文件的总大小超过100M时,MySQL会自动创建一个新的binlog日志文件。当超过7天后,MySQL会自动删除所有旧的binlog日志文件。
更改设置后,需要重新启动MySQL服务才能使其生效。
注意:
- 日志文件最大值不能设置为less than 4096 bytes。
- 如果你使用了“log_bin_trust_function_creators=1” ,MySQL版本将忽略“binlog_format = STATEMENT”,即只支持ROW模式和MIXED模式。
二、如何手动清理binlog
1.使用MySQL命令行
在MySQL命令行中,使用PURGE BINARY LOGS语句可以删除所有指定日期前创建的过期binlog日志文件。
例如,为了删除超过7天的binlog日志文件,可以运行以下命令:
1 | PURGE BINARY LOGS BEFORE DATE_SUB(NOW(), INTERVAL 7 DAY); |
2.按照binlog名称删除
1 | ## 将mysql-bin.000011之前的日志清理掉 |
3.按照时间删除
1 | ## 删除2023-03-21 18:08:00之前的binlog日志 |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Clang's Blog!
评论