mysql binlog日志自动清理及手动删除

场景:

  当开启mysql数据库主从时,会产生大量如mysql-bin.00000* log的文件,耗费大量磁盘空间。

  

解决方法:

  1.关闭mysql主从,关闭binlog

    

    

    然后重启数据库。

  2.重启mysql,开启mysql主从,设置expire_logs_days

    

    此方法需要重启mysql。

    也可以直接在mysql里设置expire_logs_days,这样不需要重启mysql

    

  3.手动清除binlog文件

    先root登录mysql

    PURGE MASTER LOGS BEFORE DATE_SUB(CURRENT_DATE, INTERVAL 10 DAY);   //删除10天前的MySQL binlog日志,附录2有关于PURGE MASTER LOGS手动删除用法及示例

    

    也可以重置master,删除所有binlog文件:

    reset master;

 清除binlog时,对从mysql的影响
  如果您有一个活性的从属服务器,该服务器当前正在读取您正在试图删除的日志之一,则本语句不会起作用,而是会失败,并伴随一个错误。不过,如果从属服务器是休止的,并且您碰巧清理了其想要读取的日志之一,则从属服务器启动后不能复制。当从属服务器正在复制时,本语句可以安全运行。您不需要停止它们。

 

  

 

posted @ 2018-03-20 10:13  那一剑的風情  阅读(1174)  评论(0)    收藏  举报