Merge 10.4 into 10.5
This commit is contained in:
commit
ca26953924
80
mysql-test/suite/galera/r/galera_log_bin_ext.result
Normal file
80
mysql-test/suite/galera/r/galera_log_bin_ext.result
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
connection node_2;
|
||||||
|
connection node_1;
|
||||||
|
connection node_1;
|
||||||
|
set global wsrep_on=OFF;
|
||||||
|
reset master;
|
||||||
|
set global wsrep_on=ON;
|
||||||
|
connection node_2;
|
||||||
|
set global wsrep_on=OFF;
|
||||||
|
reset master;
|
||||||
|
set global wsrep_on=ON;
|
||||||
|
CREATE TABLE t1 (id INT PRIMARY KEY) ENGINE=InnoDB;
|
||||||
|
INSERT INTO t1 VALUES (1);
|
||||||
|
CREATE TABLE t2 (id INT) ENGINE=InnoDB;
|
||||||
|
INSERT INTO t2 VALUES (1);
|
||||||
|
INSERT INTO t2 VALUES (1);
|
||||||
|
connection node_2;
|
||||||
|
SELECT COUNT(*) = 1 FROM t1;
|
||||||
|
COUNT(*) = 1
|
||||||
|
1
|
||||||
|
SELECT COUNT(*) = 2 FROM t2;
|
||||||
|
COUNT(*) = 2
|
||||||
|
1
|
||||||
|
connection node_1;
|
||||||
|
ALTER TABLE t1 ADD COLUMN f2 INTEGER;
|
||||||
|
include/show_binlog_events.inc
|
||||||
|
Log_name Pos Event_type Server_id End_log_pos Info
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; CREATE TABLE t1 (id INT PRIMARY KEY) ENGINE=InnoDB
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t1 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; CREATE TABLE t2 (id INT) ENGINE=InnoDB
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t2 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t2 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; ALTER TABLE t1 ADD COLUMN f2 INTEGER
|
||||||
|
connection node_2;
|
||||||
|
SELECT COUNT(*) = 2 FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 't1';
|
||||||
|
COUNT(*) = 2
|
||||||
|
1
|
||||||
|
include/show_binlog_events.inc
|
||||||
|
Log_name Pos Event_type Server_id End_log_pos Info
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; CREATE TABLE t1 (id INT PRIMARY KEY) ENGINE=InnoDB
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t1 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; CREATE TABLE t2 (id INT) ENGINE=InnoDB
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t2 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Annotate_rows # # INSERT INTO t2 VALUES (1)
|
||||||
|
hostname1-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||||
|
hostname1-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||||
|
hostname1-bin.000001 # Xid # # COMMIT /* XID */
|
||||||
|
hostname1-bin.000001 # Gtid # # GTID #-#-#
|
||||||
|
hostname1-bin.000001 # Query # # use `test`; ALTER TABLE t1 ADD COLUMN f2 INTEGER
|
||||||
|
DROP TABLE t1;
|
||||||
|
DROP TABLE t2;
|
||||||
|
#cleanup
|
||||||
|
connection node_1;
|
||||||
|
SET GLOBAL wsrep_on=OFF;
|
||||||
|
RESET MASTER;
|
@ -0,0 +1,192 @@
|
|||||||
|
--- r/galera_sst_mariabackup.result 2021-04-10 14:25:04.142716409 +0300
|
||||||
|
+++ r/galera_sst_mariabackup,debug.reject 2021-04-10 14:53:30.033162191 +0300
|
||||||
|
@@ -516,5 +516,189 @@
|
||||||
|
1
|
||||||
|
DROP TABLE t1;
|
||||||
|
COMMIT;
|
||||||
|
+Performing State Transfer on a server that has been killed and restarted
|
||||||
|
+while a DDL was in progress on it
|
||||||
|
+connection node_1;
|
||||||
|
+CREATE TABLE t1 (id int not null primary key,f1 CHAR(255)) ENGINE=InnoDB;
|
||||||
|
+SET AUTOCOMMIT=OFF;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 VALUES (1,'node1_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (2,'node1_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (3,'node1_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (4,'node1_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (5,'node1_committed_before');
|
||||||
|
+connection node_2;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 VALUES (6,'node2_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (7,'node2_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (8,'node2_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (9,'node2_committed_before');
|
||||||
|
+INSERT INTO t1 VALUES (10,'node2_committed_before');
|
||||||
|
+COMMIT;
|
||||||
|
+SET GLOBAL debug_dbug = 'd,sync.alter_opened_table';
|
||||||
|
+connection node_1;
|
||||||
|
+ALTER TABLE t1 ADD COLUMN f2 INTEGER;
|
||||||
|
+connection node_2;
|
||||||
|
+SET wsrep_sync_wait = 0;
|
||||||
|
+Killing server ...
|
||||||
|
+connection node_1;
|
||||||
|
+SET AUTOCOMMIT=OFF;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (11,'node1_committed_during');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (12,'node1_committed_during');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (13,'node1_committed_during');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (14,'node1_committed_during');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (15,'node1_committed_during');
|
||||||
|
+COMMIT;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (16,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (17,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (18,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (19,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (20,'node1_to_be_committed_after');
|
||||||
|
+connect node_1a_galera_st_kill_slave_ddl, 127.0.0.1, root, , test, $NODE_MYPORT_1;
|
||||||
|
+SET AUTOCOMMIT=OFF;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (21,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (22,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (23,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (24,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (25,'node1_to_be_rollbacked_after');
|
||||||
|
+connection node_2;
|
||||||
|
+Performing --wsrep-recover ...
|
||||||
|
+connection node_2;
|
||||||
|
+Starting server ...
|
||||||
|
+Using --wsrep-start-position when starting mysqld ...
|
||||||
|
+SET AUTOCOMMIT=OFF;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (26,'node2_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (27,'node2_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (28,'node2_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (29,'node2_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (30,'node2_committed_after');
|
||||||
|
+COMMIT;
|
||||||
|
+connection node_1;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (31,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (32,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (33,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (34,'node1_to_be_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (35,'node1_to_be_committed_after');
|
||||||
|
+COMMIT;
|
||||||
|
+SET AUTOCOMMIT=OFF;
|
||||||
|
+START TRANSACTION;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (36,'node1_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (37,'node1_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (38,'node1_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (39,'node1_committed_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (40,'node1_committed_after');
|
||||||
|
+COMMIT;
|
||||||
|
+connection node_1a_galera_st_kill_slave_ddl;
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (41,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (42,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (43,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (44,'node1_to_be_rollbacked_after');
|
||||||
|
+INSERT INTO t1 (id,f1) VALUES (45,'node1_to_be_rollbacked_after');
|
||||||
|
+ROLLBACK;
|
||||||
|
+SET AUTOCOMMIT=ON;
|
||||||
|
+SET SESSION wsrep_sync_wait=15;
|
||||||
|
+SELECT COUNT(*) AS EXPECT_3 FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 't1';
|
||||||
|
+EXPECT_3
|
||||||
|
+3
|
||||||
|
+SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
+EXPECT_35
|
||||||
|
+35
|
||||||
|
+SELECT * FROM t1;
|
||||||
|
+id f1 f2
|
||||||
|
+1 node1_committed_before NULL
|
||||||
|
+2 node1_committed_before NULL
|
||||||
|
+3 node1_committed_before NULL
|
||||||
|
+4 node1_committed_before NULL
|
||||||
|
+5 node1_committed_before NULL
|
||||||
|
+6 node2_committed_before NULL
|
||||||
|
+7 node2_committed_before NULL
|
||||||
|
+8 node2_committed_before NULL
|
||||||
|
+9 node2_committed_before NULL
|
||||||
|
+10 node2_committed_before NULL
|
||||||
|
+11 node1_committed_during NULL
|
||||||
|
+12 node1_committed_during NULL
|
||||||
|
+13 node1_committed_during NULL
|
||||||
|
+14 node1_committed_during NULL
|
||||||
|
+15 node1_committed_during NULL
|
||||||
|
+16 node1_to_be_committed_after NULL
|
||||||
|
+17 node1_to_be_committed_after NULL
|
||||||
|
+18 node1_to_be_committed_after NULL
|
||||||
|
+19 node1_to_be_committed_after NULL
|
||||||
|
+20 node1_to_be_committed_after NULL
|
||||||
|
+26 node2_committed_after NULL
|
||||||
|
+27 node2_committed_after NULL
|
||||||
|
+28 node2_committed_after NULL
|
||||||
|
+29 node2_committed_after NULL
|
||||||
|
+30 node2_committed_after NULL
|
||||||
|
+31 node1_to_be_committed_after NULL
|
||||||
|
+32 node1_to_be_committed_after NULL
|
||||||
|
+33 node1_to_be_committed_after NULL
|
||||||
|
+34 node1_to_be_committed_after NULL
|
||||||
|
+35 node1_to_be_committed_after NULL
|
||||||
|
+36 node1_committed_after NULL
|
||||||
|
+37 node1_committed_after NULL
|
||||||
|
+38 node1_committed_after NULL
|
||||||
|
+39 node1_committed_after NULL
|
||||||
|
+40 node1_committed_after NULL
|
||||||
|
+SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
+COUNT(*) = 0
|
||||||
|
+1
|
||||||
|
+COMMIT;
|
||||||
|
+connection node_1;
|
||||||
|
+SET AUTOCOMMIT=ON;
|
||||||
|
+SET SESSION wsrep_sync_wait=15;
|
||||||
|
+SELECT COUNT(*) AS EXPECT_3 FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 't1';
|
||||||
|
+EXPECT_3
|
||||||
|
+3
|
||||||
|
+SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
+EXPECT_35
|
||||||
|
+35
|
||||||
|
+SELECT * FROM t1;
|
||||||
|
+id f1 f2
|
||||||
|
+1 node1_committed_before NULL
|
||||||
|
+2 node1_committed_before NULL
|
||||||
|
+3 node1_committed_before NULL
|
||||||
|
+4 node1_committed_before NULL
|
||||||
|
+5 node1_committed_before NULL
|
||||||
|
+6 node2_committed_before NULL
|
||||||
|
+7 node2_committed_before NULL
|
||||||
|
+8 node2_committed_before NULL
|
||||||
|
+9 node2_committed_before NULL
|
||||||
|
+10 node2_committed_before NULL
|
||||||
|
+11 node1_committed_during NULL
|
||||||
|
+12 node1_committed_during NULL
|
||||||
|
+13 node1_committed_during NULL
|
||||||
|
+14 node1_committed_during NULL
|
||||||
|
+15 node1_committed_during NULL
|
||||||
|
+16 node1_to_be_committed_after NULL
|
||||||
|
+17 node1_to_be_committed_after NULL
|
||||||
|
+18 node1_to_be_committed_after NULL
|
||||||
|
+19 node1_to_be_committed_after NULL
|
||||||
|
+20 node1_to_be_committed_after NULL
|
||||||
|
+26 node2_committed_after NULL
|
||||||
|
+27 node2_committed_after NULL
|
||||||
|
+28 node2_committed_after NULL
|
||||||
|
+29 node2_committed_after NULL
|
||||||
|
+30 node2_committed_after NULL
|
||||||
|
+31 node1_to_be_committed_after NULL
|
||||||
|
+32 node1_to_be_committed_after NULL
|
||||||
|
+33 node1_to_be_committed_after NULL
|
||||||
|
+34 node1_to_be_committed_after NULL
|
||||||
|
+35 node1_to_be_committed_after NULL
|
||||||
|
+36 node1_committed_after NULL
|
||||||
|
+37 node1_committed_after NULL
|
||||||
|
+38 node1_committed_after NULL
|
||||||
|
+39 node1_committed_after NULL
|
||||||
|
+40 node1_committed_after NULL
|
||||||
|
+SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
+COUNT(*) = 0
|
||||||
|
+1
|
||||||
|
+DROP TABLE t1;
|
||||||
|
+COMMIT;
|
||||||
|
+SET GLOBAL debug_dbug = $debug_orig;
|
||||||
|
disconnect node_2;
|
||||||
|
disconnect node_1;
|
@ -0,0 +1,520 @@
|
|||||||
|
connection node_2;
|
||||||
|
connection node_1;
|
||||||
|
connection node_1;
|
||||||
|
connection node_2;
|
||||||
|
Performing State Transfer on a server that has been shut down cleanly and restarted
|
||||||
|
connection node_1;
|
||||||
|
CREATE TABLE t1 (id int not null primary key,f1 CHAR(255)) ENGINE=InnoDB;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (1,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (2,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (3,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (4,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (5,'node1_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
connection node_2;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (6,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (7,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (8,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (9,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (10,'node2_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
Shutting down server ...
|
||||||
|
connection node_1;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (11,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (12,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (13,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (14,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (15,'node1_committed_during');
|
||||||
|
COMMIT;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (16,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (17,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (18,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (19,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (20,'node1_to_be_committed_after');
|
||||||
|
connect node_1a_galera_st_shutdown_slave, 127.0.0.1, root, , test, $NODE_MYPORT_1;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (21,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (22,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (23,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (24,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (25,'node1_to_be_rollbacked_after');
|
||||||
|
connection node_2;
|
||||||
|
Starting server ...
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (26,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (27,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (28,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (29,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (30,'node2_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
INSERT INTO t1 VALUES (31,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (32,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (33,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (34,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (35,'node1_to_be_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (36,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (37,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (38,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (39,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (40,'node1_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1a_galera_st_shutdown_slave;
|
||||||
|
INSERT INTO t1 VALUES (41,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (42,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (43,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (44,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (45,'node1_to_be_rollbacked_after');
|
||||||
|
ROLLBACK;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_15 FROM t1;
|
||||||
|
EXPECT_15
|
||||||
|
35
|
||||||
|
SELECT * from t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_15 FROM t1;
|
||||||
|
EXPECT_15
|
||||||
|
35
|
||||||
|
SELECT * from t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
DROP TABLE t1;
|
||||||
|
COMMIT;
|
||||||
|
Performing State Transfer on a server that starts from a clean var directory
|
||||||
|
This is accomplished by shutting down node #2 and removing its var directory before restarting it
|
||||||
|
connection node_1;
|
||||||
|
CREATE TABLE t1 (id int not null primary key,f1 CHAR(255)) ENGINE=InnoDB;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (1,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (2,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (3,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (4,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (5,'node1_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
connection node_2;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (6,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (7,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (8,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (9,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (10,'node2_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
Shutting down server ...
|
||||||
|
connection node_1;
|
||||||
|
Cleaning var directory ...
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (11,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (12,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (13,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (14,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (15,'node1_committed_during');
|
||||||
|
COMMIT;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (16,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (17,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (18,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (19,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (20,'node1_to_be_committed_after');
|
||||||
|
connect node_1a_galera_st_clean_slave, 127.0.0.1, root, , test, $NODE_MYPORT_1;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (21,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (22,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (23,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (24,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (25,'node1_to_be_rollbacked_after');
|
||||||
|
connection node_2;
|
||||||
|
Starting server ...
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (26,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (27,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (28,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (29,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (30,'node2_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
INSERT INTO t1 VALUES (31,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (32,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (33,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (34,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (35,'node1_to_be_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (36,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (37,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (38,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (39,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (40,'node1_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1a_galera_st_clean_slave;
|
||||||
|
INSERT INTO t1 VALUES (41,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (42,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (43,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (44,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (45,'node1_to_be_rollbacked_after');
|
||||||
|
ROLLBACK;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
EXPECT_35
|
||||||
|
35
|
||||||
|
SELECT * from t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
EXPECT_35
|
||||||
|
35
|
||||||
|
SELECT * from t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
DROP TABLE t1;
|
||||||
|
COMMIT;
|
||||||
|
Performing State Transfer on a server that has been killed and restarted
|
||||||
|
connection node_1;
|
||||||
|
CREATE TABLE t1 (id int not null primary key,f1 CHAR(255)) ENGINE=InnoDB;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (1,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (2,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (3,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (4,'node1_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (5,'node1_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
connection node_2;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (6,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (7,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (8,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (9,'node2_committed_before');
|
||||||
|
INSERT INTO t1 VALUES (10,'node2_committed_before');
|
||||||
|
COMMIT;
|
||||||
|
Killing server ...
|
||||||
|
connection node_1;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (11,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (12,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (13,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (14,'node1_committed_during');
|
||||||
|
INSERT INTO t1 VALUES (15,'node1_committed_during');
|
||||||
|
COMMIT;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (16,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (17,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (18,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (19,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (20,'node1_to_be_committed_after');
|
||||||
|
connect node_1a_galera_st_kill_slave, 127.0.0.1, root, , test, $NODE_MYPORT_1;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (21,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (22,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (23,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (24,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (25,'node1_to_be_rollbacked_after');
|
||||||
|
connection node_2;
|
||||||
|
Performing --wsrep-recover ...
|
||||||
|
Starting server ...
|
||||||
|
Using --wsrep-start-position when starting mysqld ...
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (26,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (27,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (28,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (29,'node2_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (30,'node2_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
INSERT INTO t1 VALUES (31,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (32,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (33,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (34,'node1_to_be_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (35,'node1_to_be_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
SET AUTOCOMMIT=OFF;
|
||||||
|
START TRANSACTION;
|
||||||
|
INSERT INTO t1 VALUES (36,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (37,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (38,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (39,'node1_committed_after');
|
||||||
|
INSERT INTO t1 VALUES (40,'node1_committed_after');
|
||||||
|
COMMIT;
|
||||||
|
connection node_1a_galera_st_kill_slave;
|
||||||
|
INSERT INTO t1 VALUES (41,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (42,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (43,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (45,'node1_to_be_rollbacked_after');
|
||||||
|
INSERT INTO t1 VALUES (46,'node1_to_be_rollbacked_after');
|
||||||
|
ROLLBACK;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
EXPECT_35
|
||||||
|
35
|
||||||
|
SELECT * FROM t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
COMMIT;
|
||||||
|
connection node_1;
|
||||||
|
SET AUTOCOMMIT=ON;
|
||||||
|
SET SESSION wsrep_sync_wait=15;
|
||||||
|
SELECT COUNT(*) AS EXPECT_35 FROM t1;
|
||||||
|
EXPECT_35
|
||||||
|
35
|
||||||
|
SELECT * FROM t1;
|
||||||
|
id f1
|
||||||
|
1 node1_committed_before
|
||||||
|
2 node1_committed_before
|
||||||
|
3 node1_committed_before
|
||||||
|
4 node1_committed_before
|
||||||
|
5 node1_committed_before
|
||||||
|
6 node2_committed_before
|
||||||
|
7 node2_committed_before
|
||||||
|
8 node2_committed_before
|
||||||
|
9 node2_committed_before
|
||||||
|
10 node2_committed_before
|
||||||
|
11 node1_committed_during
|
||||||
|
12 node1_committed_during
|
||||||
|
13 node1_committed_during
|
||||||
|
14 node1_committed_during
|
||||||
|
15 node1_committed_during
|
||||||
|
16 node1_to_be_committed_after
|
||||||
|
17 node1_to_be_committed_after
|
||||||
|
18 node1_to_be_committed_after
|
||||||
|
19 node1_to_be_committed_after
|
||||||
|
20 node1_to_be_committed_after
|
||||||
|
26 node2_committed_after
|
||||||
|
27 node2_committed_after
|
||||||
|
28 node2_committed_after
|
||||||
|
29 node2_committed_after
|
||||||
|
30 node2_committed_after
|
||||||
|
31 node1_to_be_committed_after
|
||||||
|
32 node1_to_be_committed_after
|
||||||
|
33 node1_to_be_committed_after
|
||||||
|
34 node1_to_be_committed_after
|
||||||
|
35 node1_to_be_committed_after
|
||||||
|
36 node1_committed_after
|
||||||
|
37 node1_committed_after
|
||||||
|
38 node1_committed_after
|
||||||
|
39 node1_committed_after
|
||||||
|
40 node1_committed_after
|
||||||
|
SELECT COUNT(*) = 0 FROM (SELECT COUNT(*) AS c, f1 FROM t1 GROUP BY f1 HAVING c NOT IN (5, 10)) AS a1;
|
||||||
|
COUNT(*) = 0
|
||||||
|
1
|
||||||
|
DROP TABLE t1;
|
||||||
|
COMMIT;
|
||||||
|
disconnect node_2;
|
||||||
|
disconnect node_1;
|
11
mysql-test/suite/galera/t/galera_log_bin_ext.cnf
Normal file
11
mysql-test/suite/galera/t/galera_log_bin_ext.cnf
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
!include ../galera_2nodes.cnf
|
||||||
|
|
||||||
|
[mysqld.1]
|
||||||
|
log-bin = hostname1-bin
|
||||||
|
log-bin-index = hostname1.bdx
|
||||||
|
log-slave-updates
|
||||||
|
|
||||||
|
[mysqld.2]
|
||||||
|
log-bin = hostname2-bin
|
||||||
|
log-bin-index = hostname2.bdx
|
||||||
|
log-slave-updates
|
1
mysql-test/suite/galera/t/galera_log_bin_ext.test
Normal file
1
mysql-test/suite/galera/t/galera_log_bin_ext.test
Normal file
@ -0,0 +1 @@
|
|||||||
|
--source galera_log_bin.inc
|
@ -0,0 +1 @@
|
|||||||
|
--innodb-force-recovery=1
|
@ -0,0 +1,16 @@
|
|||||||
|
!include ../galera_2nodes.cnf
|
||||||
|
|
||||||
|
[mysqld]
|
||||||
|
wsrep_sst_method=mariabackup
|
||||||
|
wsrep_sst_auth="root:"
|
||||||
|
wsrep_debug=1
|
||||||
|
|
||||||
|
[mysqld.1]
|
||||||
|
wsrep_provider_options='base_port=@mysqld.1.#galera_port;gcache.size=1;pc.ignore_sb=true'
|
||||||
|
|
||||||
|
[mysqld.2]
|
||||||
|
wsrep_provider_options='base_port=@mysqld.2.#galera_port;gcache.size=1;pc.ignore_sb=true'
|
||||||
|
|
||||||
|
[sst]
|
||||||
|
transferfmt=@ENV.MTR_GALERA_TFMT
|
||||||
|
streamfmt=mbstream
|
@ -0,0 +1,20 @@
|
|||||||
|
--source include/big_test.inc
|
||||||
|
--source include/galera_cluster.inc
|
||||||
|
--source include/have_innodb.inc
|
||||||
|
--source include/have_mariabackup.inc
|
||||||
|
|
||||||
|
# Save original auto_increment_offset values.
|
||||||
|
--let $node_1=node_1
|
||||||
|
--let $node_2=node_2
|
||||||
|
--source include/auto_increment_offset_save.inc
|
||||||
|
|
||||||
|
--source suite/galera/include/galera_st_shutdown_slave.inc
|
||||||
|
--source suite/galera/include/galera_st_clean_slave.inc
|
||||||
|
|
||||||
|
--source suite/galera/include/galera_st_kill_slave.inc
|
||||||
|
--source suite/galera/include/galera_st_kill_slave_ddl.inc
|
||||||
|
|
||||||
|
# Restore original auto_increment_offset values.
|
||||||
|
--source include/auto_increment_offset_restore.inc
|
||||||
|
|
||||||
|
--source include/galera_end.inc
|
@ -44,6 +44,7 @@ WSREP_SST_OPT_HOST_ESCAPED=""
|
|||||||
INNODB_DATA_HOME_DIR="${INNODB_DATA_HOME_DIR:-}"
|
INNODB_DATA_HOME_DIR="${INNODB_DATA_HOME_DIR:-}"
|
||||||
INNODB_LOG_GROUP_HOME="${INNODB_LOG_GROUP_HOME:-}"
|
INNODB_LOG_GROUP_HOME="${INNODB_LOG_GROUP_HOME:-}"
|
||||||
INNODB_UNDO_DIR="${INNODB_UNDO_DIR:-}"
|
INNODB_UNDO_DIR="${INNODB_UNDO_DIR:-}"
|
||||||
|
INNODB_FORCE_RECOVERY=""
|
||||||
INNOEXTRA=""
|
INNOEXTRA=""
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
@ -229,7 +230,7 @@ case "$1" in
|
|||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
'--binlog-index'|'--log-bin-index')
|
'--binlog-index'|'--log-bin-index')
|
||||||
readonly WSREP_SST_OPT_BINLOG_INDEX="$2"
|
WSREP_SST_OPT_BINLOG_INDEX="$2"
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
'--log-basename')
|
'--log-basename')
|
||||||
@ -382,6 +383,14 @@ case "$1" in
|
|||||||
fi
|
fi
|
||||||
skip_mysqld_arg=1
|
skip_mysqld_arg=1
|
||||||
;;
|
;;
|
||||||
|
'--innodb-force-recovery')
|
||||||
|
if [ -n "$value" ]; then
|
||||||
|
if [ "$value" -ne 0 ]; then
|
||||||
|
INNODB_FORCE_RECOVERY="$value"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
skip_mysqld_arg=1
|
||||||
|
;;
|
||||||
'--log-bin')
|
'--log-bin')
|
||||||
if [ -z "$WSREP_SST_OPT_BINLOG" ]; then
|
if [ -z "$WSREP_SST_OPT_BINLOG" ]; then
|
||||||
MYSQLD_OPT_LOG_BIN="$value"
|
MYSQLD_OPT_LOG_BIN="$value"
|
||||||
@ -444,7 +453,7 @@ if [ -n "${MYSQLD_OPT_LOG_BIN:-}" -a \
|
|||||||
fi
|
fi
|
||||||
if [ -n "${MYSQLD_OPT_LOG_BIN_INDEX:-}" -a \
|
if [ -n "${MYSQLD_OPT_LOG_BIN_INDEX:-}" -a \
|
||||||
-z "$WSREP_SST_OPT_BINLOG_INDEX" ]; then
|
-z "$WSREP_SST_OPT_BINLOG_INDEX" ]; then
|
||||||
readonly WSREP_SST_OPT_BINLOG_INDEX="$MYSQLD_OPT_LOG_BIN_INDEX"
|
WSREP_SST_OPT_BINLOG_INDEX="$MYSQLD_OPT_LOG_BIN_INDEX"
|
||||||
fi
|
fi
|
||||||
if [ -n "${MYSQLD_OPT_DATADIR:-}" -a \
|
if [ -n "${MYSQLD_OPT_DATADIR:-}" -a \
|
||||||
-z "$WSREP_SST_OPT_DATA" ]; then
|
-z "$WSREP_SST_OPT_DATA" ]; then
|
||||||
@ -499,6 +508,7 @@ if [ -n "$WSREP_SST_OPT_BINLOG" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
readonly INNODB_FORCE_RECOVERY
|
||||||
readonly WSREP_SST_OPT_MYSQLD
|
readonly WSREP_SST_OPT_MYSQLD
|
||||||
|
|
||||||
get_binlog()
|
get_binlog()
|
||||||
@ -553,6 +563,16 @@ get_binlog()
|
|||||||
# is already defined above):
|
# is already defined above):
|
||||||
readonly WSREP_SST_OPT_BINLOG_INDEX="$WSREP_SST_OPT_BINLOG.index"
|
readonly WSREP_SST_OPT_BINLOG_INDEX="$WSREP_SST_OPT_BINLOG.index"
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
# Remove all directories from the index file path:
|
||||||
|
local filename="${WSREP_SST_OPT_BINLOG_INDEX##*/}"
|
||||||
|
# Check if the index file name contains the extension:
|
||||||
|
if [ "${filename%.*}" = "$filename" ]; then
|
||||||
|
# Let's add the default extension (".index"):
|
||||||
|
readonly WSREP_SST_OPT_BINLOG_INDEX="$WSREP_SST_OPT_BINLOG_INDEX.index"
|
||||||
|
else
|
||||||
|
readonly WSREP_SST_OPT_BINLOG_INDEX
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -951,7 +951,11 @@ setup_commands()
|
|||||||
if [ -n "$WSREP_SST_OPT_MYSQLD" ]; then
|
if [ -n "$WSREP_SST_OPT_MYSQLD" ]; then
|
||||||
mysqld_args="--mysqld-args $WSREP_SST_OPT_MYSQLD"
|
mysqld_args="--mysqld-args $WSREP_SST_OPT_MYSQLD"
|
||||||
fi
|
fi
|
||||||
INNOAPPLY="$BACKUP_BIN --prepare $disver $iapts $INNOEXTRA --target-dir='$DATA' --datadir='$DATA' $mysqld_args $INNOAPPLY"
|
if [ -z "$INNODB_FORCE_RECOVERY" ]; then
|
||||||
|
INNOAPPLY="$BACKUP_BIN --prepare $disver $iapts $INNOEXTRA --target-dir='$DATA' --datadir='$DATA' $mysqld_args $INNOAPPLY"
|
||||||
|
else
|
||||||
|
INNOAPPLY="$BACKUP_BIN --prepare $disver $iapts $INNOEXTRA --innodb-force-recovery=$INNODB_FORCE_RECOVERY --target-dir='$DATA' --datadir='$DATA' $mysqld_args $INNOAPPLY"
|
||||||
|
fi
|
||||||
INNOMOVE="$BACKUP_BIN $WSREP_SST_OPT_CONF --move-back $disver $impts --force-non-empty-directories --target-dir='$DATA' --datadir='${TDATA:-$DATA}' $INNOMOVE"
|
INNOMOVE="$BACKUP_BIN $WSREP_SST_OPT_CONF --move-back $disver $impts --force-non-empty-directories --target-dir='$DATA' --datadir='${TDATA:-$DATA}' $INNOMOVE"
|
||||||
INNOBACKUP="$BACKUP_BIN $WSREP_SST_OPT_CONF --backup $disver $iopts $tmpopts $INNOEXTRA --galera-info --stream=$sfmt --target-dir='$itmpdir' --datadir='$DATA' $mysqld_args $INNOBACKUP"
|
INNOBACKUP="$BACKUP_BIN $WSREP_SST_OPT_CONF --backup $disver $iopts $tmpopts $INNOEXTRA --galera-info --stream=$sfmt --target-dir='$itmpdir' --datadir='$DATA' $mysqld_args $INNOBACKUP"
|
||||||
}
|
}
|
||||||
@ -1245,8 +1249,8 @@ then
|
|||||||
cd "$binlog_dir"
|
cd "$binlog_dir"
|
||||||
wsrep_log_info "Cleaning the binlog directory $binlog_dir as well"
|
wsrep_log_info "Cleaning the binlog directory $binlog_dir as well"
|
||||||
rm -fv "$WSREP_SST_OPT_BINLOG".[0-9]* 1>&2 \+ || true
|
rm -fv "$WSREP_SST_OPT_BINLOG".[0-9]* 1>&2 \+ || true
|
||||||
binlog_index="${WSREP_SST_OPT_BINLOG_INDEX%.index}.index"
|
[ -f "$WSREP_SST_OPT_BINLOG_INDEX" ] && \
|
||||||
[ -f "$binlog_index" ] && rm -fv "$binlog_index" 1>&2 \+ || true
|
rm -fv "$WSREP_SST_OPT_BINLOG_INDEX" 1>&2 \+ || true
|
||||||
cd "$OLD_PWD"
|
cd "$OLD_PWD"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -1321,7 +1325,7 @@ then
|
|||||||
|
|
||||||
cd "$BINLOG_DIRNAME"
|
cd "$BINLOG_DIRNAME"
|
||||||
for bfile in $(ls -1 "$BINLOG_FILENAME".[0-9]*); do
|
for bfile in $(ls -1 "$BINLOG_FILENAME".[0-9]*); do
|
||||||
echo "$BINLOG_DIRNAME/$bfile" >> "${WSREP_SST_OPT_BINLOG_INDEX%.index}.index"
|
echo "$BINLOG_DIRNAME/$bfile" >> "$WSREP_SST_OPT_BINLOG_INDEX"
|
||||||
done
|
done
|
||||||
cd "$OLD_PWD"
|
cd "$OLD_PWD"
|
||||||
|
|
||||||
|
@ -392,7 +392,7 @@ EOF
|
|||||||
# Prepare binlog files
|
# Prepare binlog files
|
||||||
cd "$BINLOG_DIRNAME"
|
cd "$BINLOG_DIRNAME"
|
||||||
|
|
||||||
binlog_files_full=$(tail -n $BINLOG_N_FILES "${WSREP_SST_OPT_BINLOG_INDEX%.index}.index")
|
binlog_files_full=$(tail -n $BINLOG_N_FILES "$WSREP_SST_OPT_BINLOG_INDEX")
|
||||||
|
|
||||||
binlog_files=""
|
binlog_files=""
|
||||||
for ii in $binlog_files_full
|
for ii in $binlog_files_full
|
||||||
@ -732,7 +732,7 @@ EOF
|
|||||||
if [ -f "$BINLOG_TAR_FILE" ]; then
|
if [ -f "$BINLOG_TAR_FILE" ]; then
|
||||||
cd "$BINLOG_DIRNAME"
|
cd "$BINLOG_DIRNAME"
|
||||||
|
|
||||||
binlog_index="${WSREP_SST_OPT_BINLOG_INDEX%.index}.index"
|
binlog_index="$WSREP_SST_OPT_BINLOG_INDEX"
|
||||||
|
|
||||||
# Clean up old binlog files first
|
# Clean up old binlog files first
|
||||||
rm -f "$BINLOG_FILENAME".[0-9]*
|
rm -f "$BINLOG_FILENAME".[0-9]*
|
||||||
|
@ -784,7 +784,7 @@ int mdl_iterate(mdl_iterator_callback callback, void *arg)
|
|||||||
my_hash_value_type mdl_hash_function(CHARSET_INFO *cs,
|
my_hash_value_type mdl_hash_function(CHARSET_INFO *cs,
|
||||||
const uchar *key, size_t length)
|
const uchar *key, size_t length)
|
||||||
{
|
{
|
||||||
MDL_key *mdl_key= (MDL_key*) (key - my_offsetof(MDL_key, m_ptr));
|
MDL_key *mdl_key= (MDL_key*) (key - offsetof(MDL_key, m_ptr));
|
||||||
return mdl_key->hash_value();
|
return mdl_key->hash_value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -376,7 +376,6 @@ protected:
|
|||||||
*/
|
*/
|
||||||
bool closed;
|
bool closed;
|
||||||
|
|
||||||
public:
|
|
||||||
explicit Json_writer_struct(Json_writer *writer)
|
explicit Json_writer_struct(Json_writer *writer)
|
||||||
: my_writer(writer)
|
: my_writer(writer)
|
||||||
{
|
{
|
||||||
|
@ -5666,14 +5666,14 @@ static bool update_locale(sys_var *self, THD* thd, enum_var_type type)
|
|||||||
static Sys_var_struct Sys_lc_messages(
|
static Sys_var_struct Sys_lc_messages(
|
||||||
"lc_messages", "Set the language used for the error messages",
|
"lc_messages", "Set the language used for the error messages",
|
||||||
SESSION_VAR(lc_messages), NO_CMD_LINE,
|
SESSION_VAR(lc_messages), NO_CMD_LINE,
|
||||||
my_offsetof(MY_LOCALE, name), DEFAULT(&my_default_lc_messages),
|
offsetof(MY_LOCALE, name), DEFAULT(&my_default_lc_messages),
|
||||||
NO_MUTEX_GUARD, NOT_IN_BINLOG, ON_CHECK(check_locale), ON_UPDATE(update_locale));
|
NO_MUTEX_GUARD, NOT_IN_BINLOG, ON_CHECK(check_locale), ON_UPDATE(update_locale));
|
||||||
|
|
||||||
static Sys_var_struct Sys_lc_time_names(
|
static Sys_var_struct Sys_lc_time_names(
|
||||||
"lc_time_names", "Set the language used for the month "
|
"lc_time_names", "Set the language used for the month "
|
||||||
"names and the days of the week",
|
"names and the days of the week",
|
||||||
SESSION_VAR(lc_time_names), NO_CMD_LINE,
|
SESSION_VAR(lc_time_names), NO_CMD_LINE,
|
||||||
my_offsetof(MY_LOCALE, name), DEFAULT(&my_default_lc_time_names),
|
offsetof(MY_LOCALE, name), DEFAULT(&my_default_lc_time_names),
|
||||||
NO_MUTEX_GUARD, IN_BINLOG, ON_CHECK(check_locale));
|
NO_MUTEX_GUARD, IN_BINLOG, ON_CHECK(check_locale));
|
||||||
|
|
||||||
static Sys_var_tz Sys_time_zone(
|
static Sys_var_tz Sys_time_zone(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user