• MYSQL正确删除binlog的方法


    1.查找:

    1
    2
    3
    4
    5
    6
    7
    8
    MySQL> show binary logs;
    +—————-+———–+
    | Log_name | File_size |
    +—————-+———–+
    | mysql-bin.000001 | 150462942 |
    | mysql-bin.000002 | 125 |
    | mysql-bin.000003 | 106 |
    +—————-+———–+

    2.删除bin-log(删除mysql-bin.000003之前的而没有包含mysql-bin.000003)

    1
    2
    mysql> purge binary logs to 'mysql-bin.000003';
    Query OK, 0 rows affected (0.16 sec)

    3. 查询结果(现在只有一条记录了.)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    mysql> show binlog events/G
    *************************** 1. row ***************************
    Log_name: mysql-bin.000003
    Pos: 4
    Event_type: Format_desc
    Server_id: 1
    End_log_pos: 106
    Info: Server ver: 5.1.26-rc-log, Binlog ver: 4
    1 row in set (0.01 sec)
    (mysql-bin.000001和mysql-bin.000002已被删除)
    mysql> show binary logs;
    +—————-+———–+
    | Log_name | File_size |
    +—————-+———–+
    | mysql-bin.000003 | 106 |
    +—————-+———–+
    1 row in set (0.00 sec)

    (删除的其它格式运用!)

    1
    2
    PURGE {MASTER | BINARY} LOGS TO 'log_name'
    PURGE {MASTER | BINARY} LOGS BEFORE 'date'

    用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。

    例如:

    1
    2
    PURGE MASTER LOGS TO 'mysql-bin.010′;
    PURGE MASTER LOGS BEFORE '2008-06-22 13:00:00′;

    清除3天前的 binlog

    1
    PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY);

    BEFORE变量的date自变量可以为'YYYY-MM-DD hh:mm:ss'格式。MASTER和BINARY是同义词。

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

    要清理日志,需按照以下步骤:

    1. 在每个从属服务器上,使用SHOW SLAVE STATUS来检查它正在读取哪个日志。

    2. 使用SHOW MASTER LOGS获得主服务器上的一系列日志。

    3. 在所有的从属服务器中判定最早的日志。这个是目标日志。如果所有的从属服务器是更新的,这是清单上的最后一个日志。

    4. 制作您将要删除的所有日志的备份。(这个步骤是自选的,但是建议采用。)

    5. 清理所有的日志,但是不包括目标日志。

    在contab设置:

    复制代码 代码如下:
    0 1 * * *  `mysql -uroot -e 'PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY);'`
  • 相关阅读:
    SceneBuilder 打不开 .fxml文件,只在任务栏显示
    JDK1.6 1.7 1.8 多版本windows安装 执行命令java -version 版本不变的问题
    新手根据菜鸟教程安装docker,从No package docker-io available开始遇到的坑...
    Linux安装mysql
    用Eclipse搭建ssh框架
    前端面试之vue相关的面试题
    前端面试之闭包理解
    HTML5新规范和CSS3新特性
    vue2.0项目创建之环境变量配置
    windows下SVN服务器搭建--VisualSVN与TortoiseSVN的配置安装
  • 原文地址:https://www.cnblogs.com/xzlive/p/12156250.html
Copyright © 2020-2023  润新知