diff options
author | Sergey Vojtovich <svoj@mariadb.org> | 2018-12-06 19:23:24 +0400 |
---|---|---|
committer | Monty <monty@mariadb.org> | 2018-12-09 22:12:28 +0200 |
commit | 8cf7e3459d7309ce122824146260c4aecfa6ca77 (patch) | |
tree | 845a4269cf31cc0b169fb56d1765f690f3bc61f7 /mysql-test/main/backup_lock.test | |
parent | c0ca164b1ce48ec8bf9b95c95c94ba62dde1f29a (diff) | |
download | mariadb-git-8cf7e3459d7309ce122824146260c4aecfa6ca77.tar.gz |
Moved early check for table existance to mysql_execute_command()
MDEV-17772 - 3 way lock : ALTER, MDL, BACKUP STAGE BLOCK_DDL
While waiting for a (potentially long) RO transaction or SELECT, DDL and
LOCK TABLES ... WRITE hold protection against FTWRL and BACKUP STAGE.
This effectively makes FTWRL/BACKUP STAGE indirectly wait for this RO
transaction or SELECT to finish. Which is not great, as otherwise we
could do something useful meanwhile.
With this patch BACKUP lock is attempted to be acquired after TABLE/SCHEMA
locks. If this attempt fails, TABLE/SCHEMA locks gets released and we
start waiting for BACKUP lock. When wait finishes, BACKUP lock is released
(to avoid deadlocks) and we attempt to acquire all locks once again.
Other changes:
- Take MDL lock before testing if table exists as part of
CREATE TABLE ... IF EXISTS. This change was an effect of changes in
lock_table_name and removes an inconsistency where one could get
different error messages from CREATE TABLE .. IF EXISTS depending on
active mdl locks.
One effect of this change is that we don't binary log CREATE TABLE IF
EXISTS if the table exists. This was done because old code was sometimes
behaving inconsistenly (it was logged some time and not other times)
and sending the query to the slave could make the slave even more
inconsistent as there is not guarantee that the new table will have
the same definition as the old table on the master.
Diffstat (limited to 'mysql-test/main/backup_lock.test')
-rw-r--r-- | mysql-test/main/backup_lock.test | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/mysql-test/main/backup_lock.test b/mysql-test/main/backup_lock.test index aafeb3a2d4b..d6db7a6364e 100644 --- a/mysql-test/main/backup_lock.test +++ b/mysql-test/main/backup_lock.test @@ -142,8 +142,7 @@ let $wait_condition= --error ER_LOCK_WAIT_TIMEOUT SET STATEMENT lock_wait_timeout=0 FOR SELECT * FROM t1; ---error ER_LOCK_WAIT_TIMEOUT -SET STATEMENT lock_wait_timeout=0 FOR backup stage block_ddl; +backup stage block_ddl; SELECT LOCK_MODE, LOCK_TYPE, TABLE_SCHEMA, TABLE_NAME FROM information_schema.metadata_lock_info; backup stage end; @@ -195,15 +194,10 @@ SET STATEMENT lock_wait_timeout=0 FOR DROP TABLE t1; connection con2; backup stage start; backup stage flush; ---send backup stage block_ddl +backup stage block_ddl; connection default; -let $wait_condition= - select count(*) = 1 from information_schema.processlist - where state = "Waiting for backup lock"; ---source include/wait_condition.inc commit; connection con2; ---reap backup stage end; connection con1; --reap # DROP TABLE |