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

  • 相关阅读:
    嵌套循环
    for循环
    while循环
    switch多选择结构
    python9--内存管理 引用计数 标记清除 分代回收
    python8--文件操作 with。。。open语法
    python7 数据类型的相互转化 字符编码
    python6-深浅拷贝 元组类型 字典类型 集合类型
    python5 数字类型 字符串类型 列表类型
    python4 分支结构,循环结构 for循环
  • 原文地址:https://www.cnblogs.com/gaogao67/p/10483496.html
Copyright © 2011-2022 走看看