博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
清理mysql空间不足_清理MySQL bin-log 日志过大,解决空间不足
阅读量:7025 次
发布时间:2019-06-28

本文共 758 字,大约阅读时间需要 2 分钟。

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

MySQL bin-log 是干嘛的?

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

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

怎么清理 MySQL bin-log 呢?

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

reset master

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

PURGE {MASTER | BINARY} LOGS BEFORE 'date'

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

PURGE {MASTER | BINARY} LOGS BEFORE '2016-04-06 00:00:00'

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

MySQL 的 expire_logs_days 参数

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

expire_logs_days = 5 // 表示日志保留5天,超过5天则设置为过期的。

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

重启 MySQL

bin-log 文件大小达到参数 max_binlog_size 限制;

手工执行清理命令。

转载地址:http://dzsxl.baihongyu.com/

你可能感兴趣的文章
[LeetCode] Distinct Subsequences
查看>>
Android gif 录屏
查看>>
51Nod 1277 字符串中的最大值(KMP,裸题)
查看>>
docker~windows版本的安装与使用
查看>>
eclipse集承jboss服务器
查看>>
Web APi之认证(Authentication)两种实现方式后续【三】(十五)
查看>>
如何建设高可用系统
查看>>
用户中心系统设计
查看>>
创建索引的两种方式比对
查看>>
阿里云计算公司总部开建 2021年竣工
查看>>
详解go语言的array和slice 【一】
查看>>
Microsoft Store 开发者分成已涨到 95%
查看>>
[20150803]无法通过sql_id找到sql语句2.txt
查看>>
简单分析percona-zabbix-templates
查看>>
VK11(SD) vs. MKE1(MM)
查看>>
ORACLE RAC 11.2.0.4 for RHEL6.8安装遭遇PRVF 9992与DBCA遭遇ORA-19504&ORA-15001
查看>>
持续近7个小时的索引扫描的查询优化分析
查看>>
相对传统桌面设计器,在线报表设计器价值何在?
查看>>
值得推荐的几部日本电影(三)(r10笔记第29天)
查看>>
攻城狮的自我营销
查看>>