mirror of
https://github.com/MariaDB/server.git
synced 2025-01-24 07:44:22 +01:00
9ff272fbbd
DATABASE with open HANDLER" Remove LOCK_create_db, database name locks, and use metadata locks instead. This exposes CREATE/DROP/ALTER DATABASE statements to the graph-based deadlock detector in MDL, and paves the way for a safe, deadlock-free implementation of RENAME DATABASE. Database DDL statements will now take exclusive metadata locks on the database name, while table/view/routine DDL statements take intention exclusive locks on the database name. This prevents race conditions between database DDL and table/view/routine DDL. (e.g. DROP DATABASE with concurrent CREATE/ALTER/DROP TABLE) By adding database name locks, this patch implements WL#4450 "DDL locking: CREATE/DROP DATABASE must use database locks" and WL#4985 "DDL locking: namespace/hierarchical locks". The patch also changes code to use init_one_table() where appropriate. The new lock_table_names() function requires TABLE_LIST::db_length to be set correctly, and this is taken care of by init_one_table(). This patch also adds a simple template to help work with the mysys HASH data structure. Most of the patch was written by Konstantin Osipov.
65 lines
2.4 KiB
Text
65 lines
2.4 KiB
Text
DROP TABLE IF EXISTS t1, t2;
|
|
SET DEBUG_SYNC= 'RESET';
|
|
#
|
|
# Bug#42438: Crash ha_partition::change_table_ptr
|
|
# Test when remove partitioning is done while drop table is waiting
|
|
# for the table.
|
|
# After MDL was introduced, there is no longer any race, so test is done
|
|
# by adding a small sleep to verify that the delete waits.
|
|
# Con 1
|
|
SET DEBUG_SYNC= 'RESET';
|
|
CREATE TABLE t1
|
|
(a INTEGER,
|
|
b INTEGER NOT NULL,
|
|
KEY (b))
|
|
ENGINE = MYISAM
|
|
/*!50100 PARTITION BY RANGE (a)
|
|
(PARTITION p0 VALUES LESS THAN (2),
|
|
PARTITION p1 VALUES LESS THAN (20),
|
|
PARTITION p2 VALUES LESS THAN (100),
|
|
PARTITION p3 VALUES LESS THAN MAXVALUE ) */;
|
|
SET SESSION debug= "+d,sleep_before_create_table_no_lock";
|
|
SET DEBUG_SYNC= 'alter_table_before_create_table_no_lock SIGNAL removing_partitioning WAIT_FOR waiting_for_alter';
|
|
SET DEBUG_SYNC= 'alter_table_before_main_binlog SIGNAL partitioning_removed';
|
|
ALTER TABLE t1 REMOVE PARTITIONING;
|
|
# Con default
|
|
SET DEBUG_SYNC= 'now WAIT_FOR removing_partitioning';
|
|
SET DEBUG_SYNC= 'mdl_acquire_lock_wait SIGNAL waiting_for_alter';
|
|
SET DEBUG_SYNC= 'rm_table_part2_before_delete_table WAIT_FOR partitioning_removed';
|
|
DROP TABLE IF EXISTS t1;
|
|
# Con 1
|
|
SET SESSION debug= "-d,sleep_before_create_table_no_lock";
|
|
SET DEBUG_SYNC= 'RESET';
|
|
SET DEBUG_SYNC= 'RESET';
|
|
#
|
|
# Bug#42438: Crash ha_partition::change_table_ptr
|
|
# Test when remove partitioning is failing due to drop table is already
|
|
# in progress.
|
|
# After MDL was introduced, there is no longer any race, so test is done
|
|
# by adding a small sleep to verify that the alter waits.
|
|
CREATE TABLE t2
|
|
(a INTEGER,
|
|
b INTEGER NOT NULL,
|
|
KEY (b))
|
|
ENGINE = MYISAM
|
|
/*!50100 PARTITION BY RANGE (a)
|
|
(PARTITION p0 VALUES LESS THAN (2),
|
|
PARTITION p1 VALUES LESS THAN (20),
|
|
PARTITION p2 VALUES LESS THAN (100),
|
|
PARTITION p3 VALUES LESS THAN MAXVALUE ) */;
|
|
SET DEBUG_SYNC= 'alter_table_before_open_tables SIGNAL removing_partitions WAIT_FOR waiting_for_alter';
|
|
SET DEBUG_SYNC= 'alter_table_before_rename_result_table WAIT_FOR delete_done';
|
|
ALTER TABLE t2 REMOVE PARTITIONING;
|
|
# Con default
|
|
SET SESSION debug= "+d,sleep_before_part2_delete_table";
|
|
SET DEBUG_SYNC= 'now WAIT_FOR removing_partitions';
|
|
SET DEBUG_SYNC= 'rm_table_part2_before_delete_table SIGNAL waiting_for_alter';
|
|
SET DEBUG_SYNC= 'rm_table_part2_before_binlog SIGNAL delete_done';
|
|
DROP TABLE IF EXISTS t2;
|
|
SET SESSION debug= "-d,sleep_before_part2_delete_table";
|
|
# Con 1
|
|
ERROR 42S02: Table 'test.t2' doesn't exist
|
|
SET DEBUG_SYNC= 'RESET';
|
|
# Con default
|
|
SET DEBUG_SYNC= 'RESET';
|
|
End of 5.1 tests
|