同一個事務(wù)(語句)中,不能同時涉及事務(wù)和非事務(wù)數(shù)據(jù)表的變更,這會導(dǎo)致一個事務(wù)對應(yīng)多個GTID,違反了事務(wù)與GTID的一對一對應(yīng)原則。
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了甘肅免費建站歡迎大家使用!
[root@MySQL.sock][db1]> show create table t2 \G
*************************** 1. row ***************************
? ? ? ?Table: t2
Create Table: CREATE TABLE `t2` (
? `id` int(11) NOT NULL AUTO_INCREMENT,
? PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4
1 row in set (0.00 sec)
[root@mysql.sock][db1]> start transaction;
Query OK, 0 rows affected (0.00 sec)
[root@mysql.sock][db1]> insert into t1 select null;
Query OK, 1 row affected (0.00 sec)
Records: 1? Duplicates: 0? Warnings: 0
[root@mysql.sock][db1]> insert into t2 select null;
ERROR 1785 (HY000): Statement violates GTID consistency: Updates to non-transactional tables can only be done in either autocommitted statements or single-statement transactions, and never in the same statement as updates to transactional tables.
[root@mysql.sock][db1]> commit;
Query OK, 0 rows affected (0.01 sec)
不能使用CREATE TABLE ... SELECT語句。
[root@mysql.sock][db1]> create table t2 select * from t2;
ERROR 1786 (HY000): Statement violates GTID consistency: CREATE TABLE ... SELECT.
在事務(wù),存儲過程,函數(shù)和觸發(fā)器中,不能使用CREATE TEMPORARY TABLE,和DROP TEMPORARY TABLE語句。
[root@mysql.sock][db1]> start transaction;
Query OK, 0 rows affected (0.00 sec)
[root@mysql.sock][db1]> create temporary table t4 (id int auto_increment primary key);
ERROR 1787 (HY000): Statement violates GTID consistency: CREATE TEMPORARY TABLE and DROP TEMPORARY TABLE can only be executed outside transactional context.? These statements are also not allowed in a function or trigger because functions and triggers are also considered to be multi-statement transactions.
[root@mysql.sock][db1]> rollback;
Query OK, 0 rows affected (0.00 sec)
[root@mysql.sock][db1]> create temporary table t4 (id int auto_increment primary key);
Query OK, 0 rows affected (0.01 sec)
[root@mysql.sock][db1]> desc t4;
+-------+---------+------+-----+---------+----------------+
| Field | Type? ? | Null | Key | Default | Extra? ? ? ? ? |
+-------+---------+------+-----+---------+----------------+
| id? ? | int(11) | NO? ?| PRI | NULL? ? | auto_increment |
+-------+---------+------+-----+---------+----------------+
1 row in set (0.00 sec)
[root@mysql.sock][db1]> drop temporary table t4;
Query OK, 0 rows affected (0.00 sec)
[root@mysql.sock][db1]> desc t4;
ERROR 1146 (42S02): Table 'db1.t4' doesn't exist
開啟--enforce-gtid-consistency參數(shù),阻止執(zhí)行違反GTID-based復(fù)制原則的語句。
跳過事務(wù)的執(zhí)行,參數(shù)sql_slave_skip_counter不再起作用,需要使用如下注入空事務(wù)的方式跳過。
SET GTID_NEXT='aaa-bbb-ccc-ddd:N';
BEGIN;
COMMIT;
SET GTID_NEXT='AUTOMATIC';
CHANGE MASTER TO語句中的IGNORE_SERVER_IDS不在起作用,已經(jīng)回放過的事務(wù)會自動跳過。
在開啟GTID的實例上使用mysqldump導(dǎo)出數(shù)據(jù)時,在備份文件中會設(shè)置@@SESSION.SQL_LOG_BIN= 0,當(dāng)使用該備份文件向目標(biāo)實例導(dǎo)入數(shù)據(jù)時,不記錄二進(jìn)制日志。
在開啟GTID的實例上使用mysql_upgrade原地升級MySQL版本時,要不寫二進(jìn)制日志(這也是mysql_upgrade的默認(rèn)行為,沒開啟--write-binlog)。
當(dāng)前名稱:說GTID-GTID-based復(fù)制中的限制
本文URL:http://aaarwkj.com/article18/goopdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、軟件開發(fā)、網(wǎng)頁設(shè)計公司、網(wǎng)站設(shè)計、Google、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)