当前位置: 代码网 > it编程>数据库>Mysql > mysql binlog占用大量磁盘空间的解决方法

mysql binlog占用大量磁盘空间的解决方法

2024年06月12日 Mysql 我要评论
查看当前日志保存天数:mysql> show variables like '%expire_logs_days%';+------------------+-------+| variable

查看当前日志保存天数:

mysql> show variables like '%expire_logs_days%';
+------------------+-------+
| variable_name    | value |
+------------------+-------+
| expire_logs_days | 0     |
+------------------+-------+
1 row in set (0.08 sec)

默认是0,也就是logs不过期。

也可以使用 show variables like '%expire%' 查看是否有开启日志到期自动删除

mysql> show variables like '%expire%';
+--------------------------------+--------+
| variable_name                  | value  |
+--------------------------------+--------+
| binlog_expire_logs_auto_purge  | on     |
| binlog_expire_logs_seconds     | 432000 |
| disconnect_on_expired_password | on     |
| expire_logs_days               | 0      |
+--------------------------------+--------+
4 rows in set (0.00 sec)

设置binlog到期时间

临时生效,无需重起mysql

如果数据库此时不便重启,可以设置全局的参数,使他临时生效:

mysql> set global expire_logs_days=5;

设置了只保留5天binlog, 下次重启mysql这个参数默认会失败。

如果上面指令报错,则改为set global binlog_expire_logs_seconds=432000

mysql> set global expire_logs_days=7;
error 3683 (hy000): the option expire_logs_days and binlog_expire_logs_seconds cannot be used together. please use binlog_expire_logs_seconds to set the expire time (expire_logs_days is deprecated)
mysql> set global binlog_expire_logs_seconds=432000;
query ok, 0 rows affected (0.00 sec)
 
mysql> 
mysql> show variables like '%expire%';
+--------------------------------+--------+
| variable_name                  | value  |
+--------------------------------+--------+
| binlog_expire_logs_auto_purge  | on     |
| binlog_expire_logs_seconds     | 432000 |
| disconnect_on_expired_password | on     |
| expire_logs_days               | 0      |
+--------------------------------+--------+
4 rows in set (0.00 sec)

写入配置文件,mysql重启依旧生效

如果要永久生效,需要在my.cnf中设置
vi /etc/my.cnf
追加内容:

binlog_expire_logs_seconds=432000

手动删除binlog

也可以先手动删除binlog (purge binary logs)

删除指定的日志

mysql> purge {master | binary} logs to 'log_name'

例:删除binlog.1000

mysql> purge master logs to 'binlog.1000';

或删除指定日期之前的日志索引中的所有二进制日志。

mysql> purge {master | binary} logs before 'date'

例:删除2023-06-03 12:00:00前的文件

mysql> purge master logs before '2023-06-03 12:00:00';

例:删除3天前的日志

mysql> purge master logs before date_sub( now( ), interval 3 day);

到此这篇关于mysql binlog占用大量磁盘空间的解决方法的文章就介绍到这了,更多相关mysql binlog占用磁盘空间内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com