zoukankan      html  css  js  c++  java
  • 清理mysql bin-log

    MySQL bin-log 作用

     
    1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。
    2.主从服务器之间同步数据:主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。
     
    3.在什么时间会删除过期日志?
    每次进行 LOG flush的时会自动删除过期的日志,那么什么时间才能触发log flush,手册上的解释为:
    1. 重启 MySQL
    2. bin-log 文件大小达到参数 max_binlog_size 限制;
    3. 手工执行清理命令

    自动清理方法1:(修改配置文件和在mysql内设置参数可无需重启服务)

    vim my.cnf
    expire_logs_days = 7 // 表示日志保留7天,超过7天则设置为过期的
     
    # mysql -u root -p > show binary logs; > show variables like '%log%'; > set global expire_logs_days = 7;
     

    手动清理方法2:(推荐)

     
    如果没有主从复制,可以通过下面的命令重置数据库日志,清除之前的日志文件:
    reset master
     
    但是如果存在复制关系,应当通过 PURGE 的名来清理 bin-log 日志,语法如下:
     
    # mysql -u root -p
    > purge master logs to 'mysql-bin.010’; //清除mysql-bin.010日志
    > purge master logs before '2016-02-28 13:00:00'; //清除2016-02-28 13:00:00前的日志
    > purge master logs before date_sub(now(), interval 3 day); //清除3天前的bin日志
     
    注意,不要轻易手动去删除binlog,会导致binlog.index和真实存在的binlog不匹配,而导致expire_logs_day失效
  • 相关阅读:
    详解Bootstrap进度条组件
    详解Bootstrap缩略图组件及警示框组件
    详解Bootstrap表单组件
    spring注解-@Autowired。@Resource。@Service
    spring注解-@Transactional事务几点注意
    17_8_9 Spring 注入
    MySQL常用语句
    Mysql 远程登录及常用命令
    数据库(外键及其约束理解)
    C语言队列(数组内核)
  • 原文地址:https://www.cnblogs.com/liulj0713/p/10381615.html
Copyright © 2011-2022 走看看