Commit 1c48950e authored by Denis Protivensky's avatar Denis Protivensky Committed by Julius Goryavsky

MDEV-30536: Fix Galera bulk insert optimization MTR test

After closing https://github.com/codership/galera-bugs/issues/947,
Galera now correctly certifies table-level keys, which made bulk
insert work again.

The corresponding MTR test is made deterministic and re-enabled.

Requires Galera 26.4.19
Signed-off-by: default avatarJulius Goryavsky <julius.goryavsky@mariadb.com>
parent bac0804d
...@@ -14,7 +14,6 @@ galera_as_slave_ctas : MDEV-28378 timeout ...@@ -14,7 +14,6 @@ galera_as_slave_ctas : MDEV-28378 timeout
galera_pc_recovery : MDEV-25199 cluster fails to start up galera_pc_recovery : MDEV-25199 cluster fails to start up
galera_bf_kill_debug : timeout after 900 seconds galera_bf_kill_debug : timeout after 900 seconds
galera_ssl_upgrade : [Warning] Failed to load slave replication state from table mysql.gtid_slave_pos: 130: Incorrect file format 'gtid_slave_pos' galera_ssl_upgrade : [Warning] Failed to load slave replication state from table mysql.gtid_slave_pos: 130: Incorrect file format 'gtid_slave_pos'
galera_insert_bulk : MDEV-30536 no expected deadlock in galera_insert_bulk test
galera_sequences : MDEV-32561 WSREP FSM failure: no such a transition REPLICATING -> COMMITTED galera_sequences : MDEV-32561 WSREP FSM failure: no such a transition REPLICATING -> COMMITTED
galera_concurrent_ctas : MDEV-32779 galera_concurrent_ctas: assertion in the galera::ReplicatorSMM::finish_cert() galera_concurrent_ctas : MDEV-32779 galera_concurrent_ctas: assertion in the galera::ReplicatorSMM::finish_cert()
galera_as_slave_replay : MDEV-32780 galera_as_slave_replay: assertion in the wsrep::transaction::before_rollback() galera_as_slave_replay : MDEV-32780 galera_as_slave_replay: assertion in the wsrep::transaction::before_rollback()
......
...@@ -2,6 +2,8 @@ connection node_2; ...@@ -2,6 +2,8 @@ connection node_2;
connection node_1; connection node_1;
connection node_1; connection node_1;
CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB; CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB;
SET GLOBAL DEBUG_DBUG = 'd,sync.wsrep_apply_cb';
connection node_1;
SET foreign_key_checks = 0; SET foreign_key_checks = 0;
SET unique_checks = 0; SET unique_checks = 0;
START TRANSACTION; START TRANSACTION;
...@@ -10,11 +12,20 @@ SET foreign_key_checks = 1; ...@@ -10,11 +12,20 @@ SET foreign_key_checks = 1;
SET unique_checks = 1; SET unique_checks = 1;
INSERT INTO t1 VALUES (1001); INSERT INTO t1 VALUES (1001);
connection node_1; connection node_1;
SET DEBUG_SYNC = 'wsrep_before_certification WAIT_FOR sync.wsrep_apply_cb_reached';
SET DEBUG_SYNC = 'wsrep_after_certification SIGNAL signal.wsrep_apply_cb';
COMMIT; COMMIT;
ERROR 40001: Deadlock found when trying to get lock; try restarting transaction ERROR 40001: Deadlock found when trying to get lock; try restarting transaction
DROP TABLE t1; DROP TABLE t1;
SET GLOBAL DEBUG_DBUG = '';
SET DEBUG_SYNC = 'RESET';
connection node_1; connection node_1;
CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB; CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB;
connection node_2;
SET GLOBAL DEBUG_DBUG = 'd,sync.wsrep_apply_cb';
connection node_1;
SET foreign_key_checks = 0;
SET unique_checks = 0;
START TRANSACTION; START TRANSACTION;
connection node_2; connection node_2;
SET foreign_key_checks = 1; SET foreign_key_checks = 1;
...@@ -23,8 +34,14 @@ START TRANSACTION; ...@@ -23,8 +34,14 @@ START TRANSACTION;
INSERT INTO t1 VALUES (1001); INSERT INTO t1 VALUES (1001);
connection node_1; connection node_1;
COMMIT; COMMIT;
2 3
connection node_2; connection node_2;
SET DEBUG_SYNC = 'wsrep_before_certification WAIT_FOR sync.wsrep_apply_cb_reached';
SET DEBUG_SYNC = 'wsrep_after_certification SIGNAL signal.wsrep_apply_cb';
COMMIT; COMMIT;
ERROR 40001: Deadlock found when trying to get lock; try restarting transaction ERROR 40001: Deadlock found when trying to get lock; try restarting transaction
DROP TABLE t1; DROP TABLE t1;
SET GLOBAL DEBUG_DBUG = '';
SET DEBUG_SYNC = 'RESET';
disconnect node_2;
disconnect node_1;
...@@ -5,6 +5,8 @@ ...@@ -5,6 +5,8 @@
--source include/galera_cluster.inc --source include/galera_cluster.inc
--source include/have_innodb.inc --source include/have_innodb.inc
--source include/have_debug_sync.inc
--source include/have_debug.inc
# #
# Make bulk insert BF-abort, but regular insert succeed. # Make bulk insert BF-abort, but regular insert succeed.
...@@ -13,6 +15,10 @@ ...@@ -13,6 +15,10 @@
--connection node_1 --connection node_1
CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB; CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB;
# Delay applying of the single insert from the other node.
SET GLOBAL DEBUG_DBUG = 'd,sync.wsrep_apply_cb';
--connection node_1
# Disable foreign and unique key checks to allow bulk insert. # Disable foreign and unique key checks to allow bulk insert.
SET foreign_key_checks = 0; SET foreign_key_checks = 0;
SET unique_checks = 0; SET unique_checks = 0;
...@@ -30,7 +36,7 @@ while ($count < 1000) ...@@ -30,7 +36,7 @@ while ($count < 1000)
--connection node_2 --connection node_2
# Disable bulk insert. # Disable bulk insert on this node.
SET foreign_key_checks = 1; SET foreign_key_checks = 1;
SET unique_checks = 1; SET unique_checks = 1;
...@@ -38,10 +44,20 @@ SET unique_checks = 1; ...@@ -38,10 +44,20 @@ SET unique_checks = 1;
INSERT INTO t1 VALUES (1001); INSERT INTO t1 VALUES (1001);
--connection node_1 --connection node_1
# We need to trigger Galera-level certification conflict. For this:
# - start applying single insert from the other node before bulk insert certifies
# - certifying bulk insert will lead to the conflict
# - keep applying single insert
SET DEBUG_SYNC = 'wsrep_before_certification WAIT_FOR sync.wsrep_apply_cb_reached';
SET DEBUG_SYNC = 'wsrep_after_certification SIGNAL signal.wsrep_apply_cb';
--error ER_LOCK_DEADLOCK --error ER_LOCK_DEADLOCK
COMMIT; COMMIT;
DROP TABLE t1; DROP TABLE t1;
SET GLOBAL DEBUG_DBUG = '';
SET DEBUG_SYNC = 'RESET';
# #
# Make bulk insert succeed, but regular insert BF-abort. # Make bulk insert succeed, but regular insert BF-abort.
...@@ -50,8 +66,17 @@ DROP TABLE t1; ...@@ -50,8 +66,17 @@ DROP TABLE t1;
--connection node_1 --connection node_1
CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB; CREATE TABLE t1 (f1 INTEGER PRIMARY KEY) ENGINE=InnoDB;
--connection node_2
# Delay applying of the bulk insert from the other node.
SET GLOBAL DEBUG_DBUG = 'd,sync.wsrep_apply_cb';
--connection node_1
--let $before_bulk_keys = `SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_repl_keys'` --let $before_bulk_keys = `SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_repl_keys'`
# Disable foreign and unique key checks to allow bulk insert.
SET foreign_key_checks = 0;
SET unique_checks = 0;
START TRANSACTION; START TRANSACTION;
--let $count=0 --let $count=0
...@@ -64,8 +89,7 @@ while ($count < 1000) ...@@ -64,8 +89,7 @@ while ($count < 1000)
--enable_query_log --enable_query_log
--connection node_2 --connection node_2
# Disable bulk insert on this node.
# Disable bulk insert.
SET foreign_key_checks = 1; SET foreign_key_checks = 1;
SET unique_checks = 1; SET unique_checks = 1;
...@@ -77,12 +101,23 @@ INSERT INTO t1 VALUES (1001); ...@@ -77,12 +101,23 @@ INSERT INTO t1 VALUES (1001);
--connection node_1 --connection node_1
COMMIT; COMMIT;
# Expect two keys to be added for bulk insert: DB-level shared key and table-level exclusive key. # Expect three keys to be added for bulk insert: "zero-level" key, DB-level shared key and table-level exclusive key.
--let $bulk_keys_count = `SELECT VARIABLE_VALUE - $before_bulk_keys FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_repl_keys'` --let $bulk_keys_count = `SELECT VARIABLE_VALUE - $before_bulk_keys FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_repl_keys'`
--echo $bulk_keys_count --echo $bulk_keys_count
--connection node_2 --connection node_2
# We need to trigger Galera-level certification conflict. For this:
# - start applying bulk insert from the other node before local insert certifies
# - certifying local insert will lead to the conflict
# - keep applying bulk insert
SET DEBUG_SYNC = 'wsrep_before_certification WAIT_FOR sync.wsrep_apply_cb_reached';
SET DEBUG_SYNC = 'wsrep_after_certification SIGNAL signal.wsrep_apply_cb';
--error ER_LOCK_DEADLOCK --error ER_LOCK_DEADLOCK
COMMIT; COMMIT;
DROP TABLE t1; DROP TABLE t1;
SET GLOBAL DEBUG_DBUG = '';
SET DEBUG_SYNC = 'RESET';
--source include/galera_end.inc
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment