• mysqldump命令之single-transaction


    =========================================================
    在mysqldump中指定single-transaction时,会使用可重复读(REPEATABLE READ)事务隔离级别来保证整个dump过程中数据一致性,该选项仅对InnoDB表有用,且不能与ALTER TABLE/CREATE TABLE/DROP TABLE/RENAME TABLE/TRUNCATE TABLE等DDL操作并行。

    mysqldump的操作步骤如下:
    FLUSH TABLES;
    FLUSH TABLES WITH READ LOCK;
    SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
    START TRANSACTION WITH CONSISTENT SNAPSHOT;
    SHOW MASTER STATUS;
    UNLOCK TABLES;
    
    SHOW TABLES LIKE 'xxx'
    SET OPTION SQL_QUOTE_SHOW_CREATE=1
    SHWO CREATE TABLE 'xxx'
    SHOW FIELDS FROM 'xxx'
    SHOW TABLE STATUS LIKE 'xxx'
    SELECT /*!40001 SQL_NO_CACHE */ * FROM  xxx
    
    QUIT

    通过FLUSH TABLES WITH READ LOCK来锁定所有表,然后开启事务,由于外部事务不能对表数据进行修改,因此SHOW MASTER STATUS的数据不会发生变化,而由于事务隔离级别为REPEATABLE READ,因此在整个mysqldump过程中,获取到的数据为开始事务时的数据,因此可以保证mysqldump出来的数据一致性,并可以结合SHOW MASTER STATUS出来的数据进行恢复。


    =========================================================
    在MySQL不同版本中,mysqldump --single-transaction与DDL操作发生并行时会出现问题:
    http://www.cnblogs.com/TeyGao/p/7121232.html
    https://www.cnblogs.com/TeyGao/p/7122924.html



    =========================================================
    如果从库上开启并行复制,在从库执行mysqldump备份,执行"FLUSH TABLES WITH READ LOCK;"会与并行复制发生相互阻塞。
    https://www.cnblogs.com/TeyGao/p/8654933.html

  • 相关阅读:
    顺序表的C语言实现
    Nginx模块开发(5)————开发简单的HTTP过滤模块
    python集合(set)
    python——封装、解构
    python——杨辉三角
    python——bytes、bytearray
    python算法——求10万以内的质数
    python算法——打印菱形、对等三角、闪电
    python字符串操作
    python—冒泡排序
  • 原文地址:https://www.cnblogs.com/gaogao67/p/10483496.html
Copyright © 2020-2023  润新知