mirror of
https://github.com/MariaDB/server.git
synced 2025-12-01 17:39:21 +03:00
We will remove the parameter innodb_disallow_writes because it is badly designed and implemented. The parameter was never allowed at startup. It was only internally used by Galera snapshot transfer. If a user executed SET GLOBAL innodb_disallow_writes=ON; the server could hang even on subsequent read operations. During Galera snapshot transfer, we will block writes to implement an rsync friendly snapshot, as follows: sst_flush_tables() will acquire a global lock by executing FLUSH TABLES WITH READ LOCK, which will block any writes at the high level. sst_disable_innodb_writes(), invoked via ha_disable_internal_writes(true), will suspend or disable InnoDB background tasks or threads that could initiate writes. As part of this, log_make_checkpoint() will be invoked to ensure that anything in the InnoDB buf_pool.flush_list will be written to the data files. This has the nice side effect that the Galera joiner will avoid crash recovery. The changes to sql/wsrep.cc and to the tests are based on a prototype that was developed by Jan Lindström. Reviewed by: Jan Lindström
69 lines
2.6 KiB
Plaintext
69 lines
2.6 KiB
Plaintext
#
|
|
# This test tests a DROP empty database
|
|
#
|
|
--source include/galera_cluster.inc
|
|
--source include/have_innodb.inc
|
|
|
|
# Save original auto_increment_offset values.
|
|
--let $node_1=node_1
|
|
--let $node_2=node_2
|
|
--source include/auto_increment_offset_save.inc
|
|
|
|
# Create test database with two sets of the FTS indexes:
|
|
CREATE DATABASE fts;
|
|
USE fts;
|
|
CREATE TABLE fts_t1 (f1 INT PRIMARY KEY AUTO_INCREMENT, f2 VARCHAR(100), FULLTEXT (f2)) ENGINE=InnoDB;
|
|
CREATE TABLE fts_t2 (f2 VARCHAR(100), FULLTEXT (f2)) ENGINE=InnoDB;
|
|
|
|
# Insert 1K rows
|
|
CREATE TABLE ten (f1 INTEGER) ENGINE=InnoDB;
|
|
INSERT INTO ten VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10);
|
|
INSERT INTO fts_t1 (f2) SELECT 'foobarbaz' FROM ten AS a1, ten AS a2, ten AS a3;
|
|
INSERT INTO fts_t2 (f2) SELECT 'foobarbaz' FROM ten AS a1, ten AS a2, ten AS a3;
|
|
DROP TABLE ten;
|
|
UPDATE fts_t1 SET f2 = 'abcd';
|
|
UPDATE fts_t2 SET f2 = 'efjh';
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t1;
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t2;
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t1 where f2 = 'abcd';
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t2 where f2 = 'efjh';
|
|
|
|
# Restart the second node:
|
|
--connection node_2
|
|
--source include/restart_mysqld.inc
|
|
|
|
--connection node_1
|
|
--let $wait_condition = SELECT VARIABLE_VALUE = 2 FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME = 'wsrep_cluster_size';
|
|
--source include/wait_condition.inc
|
|
|
|
--connection node_2
|
|
--source include/wait_until_ready.inc
|
|
--let $wait_condition = SELECT COUNT(*) = 1000 FROM fts_t1 where f2 = 'abcd';
|
|
--source include/wait_condition.inc
|
|
--let $wait_condition = SELECT COUNT(*) = 1000 FROM fts_t2 where f2 = 'efjh';
|
|
--source include/wait_condition.inc
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t1;
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t2;
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t1 where f2 = 'abcd';
|
|
SELECT COUNT(*) AS EXPECT_1000 FROM fts_t2 where f2 = 'efjh';
|
|
|
|
# Drop the tables and database after nodes restarted:
|
|
--connection node_1
|
|
USE fts;
|
|
DROP TABLE fts_t1;
|
|
DROP TABLE fts_t2;
|
|
SHOW TABLES;
|
|
DROP DATABASE fts;
|
|
|
|
--connection node_2
|
|
call mtr.add_suppression("WSREP: Failed to scan the last segment to the end. Last events may be missing. Last recovered event:");
|
|
--let $wait_condition = SELECT COUNT(*) = 0 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'fts_t1';
|
|
--source include/wait_condition.inc
|
|
--let $wait_condition = SELECT COUNT(*) = 0 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'fts_t2';
|
|
--source include/wait_condition.inc
|
|
--let $wait_condition = SELECT COUNT(*) = 0 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'fts';
|
|
--source include/wait_condition.inc
|
|
|
|
# Restore original auto_increment_offset values.
|
|
--source include/auto_increment_offset_restore.inc
|