前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL bin-log 日志过大造成空间不足问题的解决方法

MySQL bin-log 日志过大造成空间不足问题的解决方法

作者头像
Denis
发布2023-04-15 10:18:25
9930
发布2023-04-15 10:18:25
举报
文章被收录于专栏:WordPress果酱WordPress果酱

前几天,一早起来,就发现 RDS 挂了,然后也无法重启,后面发现是 bin-log 日志过大,把 RDS 的空间塞满了。

MySQL bin-log 是干嘛的?

1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。

2.主从服务器之间同步数据:主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。

怎么清理 MySQL bin-log 呢?

如果没有主从复制,可以通过下面的命令重置数据库日志,清除之前的日志文件:

代码语言:javascript
复制
reset master

但是如果存在复制关系,应当通过 PURGE 的名来清理 bin-log 日志,语法如下:

代码语言:javascript
复制
PURGE {MASTER | BINARY} LOGS BEFORE 'date'

比如删除 2016-04-06 之前的:

代码语言:javascript
复制
PURGE {MASTER | BINARY} LOGS BEFORE '2016-04-06 00:00:00'

清除之后,可以使用 MySQL 的 show binary logs 命令在查看下剩下的日志。

MySQL 的 expire_logs_days 参数

MySQL 的 expire_logs_days 参数可以用来设置二进制日志自动删除/过期的天数,默认值为0,表示“没有自动删除”,例如:

代码语言:javascript
复制
expire_logs_days = 5 // 表示日志保留5天,超过5天则设置为过期的。

在什么时间会删除过期日志?每次进行 LOG flush的时会自动删除过期的日志,那么什么时间才能触发log flush,手册上的解释为:

  1. 重启 MySQL
  2. bin-log 文件大小达到参数 max_binlog_size 限制;
  3. 手工执行清理命令。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • MySQL bin-log 是干嘛的?
  • 怎么清理 MySQL bin-log 呢?
  • MySQL 的 expire_logs_days 参数
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档