mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 09:14:17 +01:00
Fix rocksdb.unique_check: do not have two threads waiting on the same name
This commit is contained in:
parent
d6444022ca
commit
ba0d8aeffa
2 changed files with 8 additions and 6 deletions
|
@ -66,12 +66,12 @@ id id2 value
|
||||||
2 1 2
|
2 1 2
|
||||||
truncate table t2;
|
truncate table t2;
|
||||||
connection con1;
|
connection con1;
|
||||||
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked1 WAIT_FOR go';
|
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked1 WAIT_FOR go1';
|
||||||
insert into t1 values (1,1);
|
insert into t1 values (1,1);
|
||||||
connection default;
|
connection default;
|
||||||
set debug_sync='now WAIT_FOR parked1';
|
set debug_sync='now WAIT_FOR parked1';
|
||||||
connection con2;
|
connection con2;
|
||||||
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked2 WAIT_FOR go';
|
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked2 WAIT_FOR go2';
|
||||||
insert into t2 values (1,1,1);
|
insert into t2 values (1,1,1);
|
||||||
connection default;
|
connection default;
|
||||||
set debug_sync='now WAIT_FOR parked2';
|
set debug_sync='now WAIT_FOR parked2';
|
||||||
|
@ -82,7 +82,8 @@ ERROR HY000: Lock wait timeout exceeded; try restarting transaction
|
||||||
insert into t2 values (2,1,2);
|
insert into t2 values (2,1,2);
|
||||||
ERROR HY000: Lock wait timeout exceeded; try restarting transaction
|
ERROR HY000: Lock wait timeout exceeded; try restarting transaction
|
||||||
connection default;
|
connection default;
|
||||||
set debug_sync='now SIGNAL go';
|
set debug_sync='now SIGNAL go1';
|
||||||
|
set debug_sync='now SIGNAL go2';
|
||||||
connection con1;
|
connection con1;
|
||||||
connection con2;
|
connection con2;
|
||||||
connection default;
|
connection default;
|
||||||
|
|
|
@ -102,14 +102,14 @@ truncate table t2;
|
||||||
|
|
||||||
# 4) simulating T1 GetForUpdate() -> T2 GetForUpdate(). T2 should fail with lock wait timeout.
|
# 4) simulating T1 GetForUpdate() -> T2 GetForUpdate(). T2 should fail with lock wait timeout.
|
||||||
connection con1;
|
connection con1;
|
||||||
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked1 WAIT_FOR go';
|
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked1 WAIT_FOR go1';
|
||||||
send insert into t1 values (1,1);
|
send insert into t1 values (1,1);
|
||||||
|
|
||||||
connection default;
|
connection default;
|
||||||
set debug_sync='now WAIT_FOR parked1';
|
set debug_sync='now WAIT_FOR parked1';
|
||||||
|
|
||||||
connection con2;
|
connection con2;
|
||||||
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked2 WAIT_FOR go';
|
set debug_sync='rocksdb.update_write_row_after_unique_check SIGNAL parked2 WAIT_FOR go2';
|
||||||
send insert into t2 values (1,1,1);
|
send insert into t2 values (1,1,1);
|
||||||
|
|
||||||
connection default;
|
connection default;
|
||||||
|
@ -123,7 +123,8 @@ insert into t1 values (1,2);
|
||||||
insert into t2 values (2,1,2);
|
insert into t2 values (2,1,2);
|
||||||
|
|
||||||
connection default;
|
connection default;
|
||||||
set debug_sync='now SIGNAL go';
|
set debug_sync='now SIGNAL go1';
|
||||||
|
set debug_sync='now SIGNAL go2';
|
||||||
|
|
||||||
connection con1;
|
connection con1;
|
||||||
reap;
|
reap;
|
||||||
|
|
Loading…
Add table
Reference in a new issue