mirror of
https://github.com/MariaDB/server.git
synced 2025-08-31 22:22:30 +03:00
MDEV-5921: In parallel replication, an error is not correctly signalled to the next transaction
When a transaction fails in parallel replication, it should signal the error to any following transactions doing wait_for_prior_commit() on it. But the code for this was incorrect, and would not correctly remember a prior error when sending the signal. This caused corruption when slave stopped due to an error. Fix by remembering the error code when we first get an error, and passing the saved error code to wakeup_subsequent_commits(). Thanks to nanyi607rao who reported this bug on maria-developers@lists.launchpad.net and analysed the root cause.
This commit is contained in:
@@ -694,6 +694,7 @@ STOP SLAVE IO_THREAD;
|
||||
SET GLOBAL debug_dbug=@old_dbug;
|
||||
SET GLOBAL slave_parallel_max_queued= @old_max_queued;
|
||||
INSERT INTO t3 VALUES (82,0);
|
||||
SET binlog_format=@old_format;
|
||||
SET debug_sync='RESET';
|
||||
include/start_slave.inc
|
||||
SELECT * FROM t3 WHERE a >= 80 ORDER BY a;
|
||||
@@ -726,6 +727,40 @@ SELECT * FROM t3 WHERE a >= 100 ORDER BY a;
|
||||
a b
|
||||
106 #
|
||||
107 #
|
||||
*** MDEV-5921: In parallel replication, an error is not correctly signalled to the next transaction ***
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL slave_parallel_threads=10;
|
||||
include/start_slave.inc
|
||||
INSERT INTO t3 VALUES (110, 1);
|
||||
SELECT * FROM t3 WHERE a >= 110 ORDER BY a;
|
||||
a b
|
||||
110 1
|
||||
SET sql_log_bin=0;
|
||||
INSERT INTO t3 VALUES (111, 666);
|
||||
SET sql_log_bin=1;
|
||||
SET debug_sync='commit_after_release_LOCK_prepare_ordered SIGNAL master_queued1 WAIT_FOR master_cont1';
|
||||
INSERT INTO t3 VALUES (111, 2);
|
||||
SET debug_sync='now WAIT_FOR master_queued1';
|
||||
SET debug_sync='commit_after_release_LOCK_prepare_ordered SIGNAL master_queued2';
|
||||
INSERT INTO t3 VALUES (112, 3);
|
||||
SET debug_sync='now WAIT_FOR master_queued2';
|
||||
SET debug_sync='now SIGNAL master_cont1';
|
||||
SET debug_sync='RESET';
|
||||
include/wait_for_slave_sql_error.inc [errno=1062]
|
||||
include/wait_for_slave_sql_to_stop.inc
|
||||
SELECT * FROM t3 WHERE a >= 110 ORDER BY a;
|
||||
a b
|
||||
110 1
|
||||
111 666
|
||||
SET sql_log_bin=0;
|
||||
DELETE FROM t3 WHERE a=111 AND b=666;
|
||||
SET sql_log_bin=1;
|
||||
START SLAVE SQL_THREAD;
|
||||
SELECT * FROM t3 WHERE a >= 110 ORDER BY a;
|
||||
a b
|
||||
110 1
|
||||
111 2
|
||||
112 3
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL slave_parallel_threads=@old_parallel_threads;
|
||||
include/start_slave.inc
|
||||
|
Reference in New Issue
Block a user