广告
返回顶部
首页 > 资讯 > 数据库 >MySQL日志保留策略:设置binlog日志保存天数、文件大小限制
  • 678
分享到

MySQL日志保留策略:设置binlog日志保存天数、文件大小限制

mysql数据库java 2023-08-16 16:08:47 678人浏览 八月长安
摘要

文章目录 一、设置binlog日志保存天数、文件大小限制二、如何手动清理binlog1.使用MySQL命令行2.按照binlog名称删除3.按照时间删除 一、设置binlog日志保存天数、文件大小限制 在Mysql中,有三


一、设置binlog日志保存天数、文件大小限制

Mysql中,有三种主要类型的日志记录:二进制日志(binlog)、错误日志和查询日志。这些日志记录对于mysql数据库的管理和维护非常重要。在本文中,我们将重点讨论如何设置binlog日志的保留策略。

默认情况下,Mysql会自动将binlog日志文件保存在主目录或指定目录下,并且不限制binlog日志文件的大小和日志保留时间。这意味着当日志文件太大或当你不再需要它们时,你需要手动删除它们。

所以,为了优化MySQL数据库的管理,我们可以通过在MySQL配置文件my.cnf中添加以下内容来设置binlog日志的保留策略:

[mysqld]#设置日志保留天数expire_logs_days=7#设置日志文件最大大小max_binlog_size=100M

以上配置将保留最近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日志文件,可以运行以下命令:

PURGE BINARY LOGS BEFORE DATE_SUB(NOW(), INTERVAL 7 DAY);

2.按照binlog名称删除

## 将mysql-bin.000011之前的日志清理掉mysql> purge binary logs to 'mysql-bin.000011';Query OK, 0 rows affected (0.01 sec)

3.按照时间删除

## 删除2023-03-21 18:08:00之前的binlog日志mysql> purge binary logs before '2023-03-21 18:08:00';Query OK, 0 rows affected, 1 warning (0.02 sec)

提示:更多内容可以访问Clang’s Blog:https://www.clang.asia/

来源地址:https://blog.csdn.net/u012899618/article/details/129790336

您可能感兴趣的文档:

--结束END--

本文标题: MySQL日志保留策略:设置binlog日志保存天数、文件大小限制

本文链接: https://www.lsjlt.com/news/371715.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作