zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    qt捕鱼达人
    linux通过源码安装gdb
    打造简易http服务器
    linux缓存同步
    NOI之后的碎碎念
    Validate至少有一个不能为空
    IOI 2020 集训队作业
    P6033 [NOIP2004 提高组] 合并果子 加强版 题解
    P3017 [USACO11MAR]Brownie Slicing G 题解
    LOJ #145. DFS 序 2 题解
  • 原文地址:https://www.cnblogs.com/gaogao67/p/10483496.html
Copyright © 2011-2022 走看看