mysql中如何设置expire

52次阅读
没有评论

共计 851 个字符,预计需要花费 3 分钟才能阅读完成。

丸趣 TV 小编给大家分享一下 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”有了一定的了解,如果想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-27发表,共计851字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)