• 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

  • 相关阅读:
    使用samba实现linux和windows文件共享
    使用li列举属性表中的某一属性
    popuptemplate的使用
    html中自动分配界面
    div中移除和添加元素
    使用v-html绑定数据,实现图片的动态转换
    使用js下载数据
    使用FeatureTable对FeatureLayer中的数据进行显示
    使用ant的checkboxGroup将列表信息添加为多选框,并根据多选框的转换进行操作
    arcgis api绘制多个点
  • 原文地址:https://www.cnblogs.com/gaogao67/p/10483496.html
Copyright © 2020-2023  润新知