mysql中如何设置expire_logs_days自动过期清理binlog


小编给大家分享一下mysql中如何设置expire_logs_days自动过期清理binlog,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
生产上有一个比较小的系统,发现mysql占用空间较大,经排查发现是binlog比较多引起的

查看binlog过期时间,设置的开发云主机域名时间为90天,这个值默认是0天,也就是说不自动清理,可以根据生产情况修改,本例修改为7天

mysql> show variables like ‘expire_logs_days’;
+——————+——-+
| Variable_name | Value |
+——————+——-+
| expire_logs_days | 90 |
+——————+——-+
1 row in set (0.00 sec)mysql> set global expire_logs_days=7;
Query OK, 0 rows affected (0.00 sec)设置之后不会立即清除,触发条件是:
binlog大小超过max_binlog_size
手动执行flush logs
重新启动时(MySQL将会new一个新文件用于记录binlog)

我们执行flush logs;

mysql> flush logs;
Query OK, 0 rows affected, 64 warnings (0.16 sec 如果binlog非常多,不要轻易设置改参数,有可能导致io争用,这时候可以使用purge命令予以清除:
将bin.000055之前的binlog清掉:

mysql>purge binary logs to ‘bin.000055’;将指定时间之前的binlog清掉:
mysql>purge binary logs before ‘2017-05-01 13:09:51’;看完了这篇文章,相信你对“mysql中如何设置expire_logs_days自动过期清理binlog”有了一定的了解,如果想了解更多相关知识,欢迎关注开发云行业资讯频道,感谢各位的阅读!

相关推荐: mysql select后面的子查询应该如何使用

本文主要给大家简单讲讲mysql select后面的子查询应该如何使用,相关专业术语大家可以上网查开发云主机域名查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望mysql select后面的子查询应该如何使用这篇文章可以给大家带来一些实际帮…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/22 19:57
下一篇 06/22 19:57

相关推荐