Details
-
Bug
-
Status: Closed (View Workflow)
-
Major
-
Resolution: Fixed
-
10.0.13-galera, 10.1.0
Description
InnoDB: Assertion failure in thread 140492273628928 in file lock0lock.cc line 4033
InnoDB: Failing assertion: lock != ctx->wait_lock
Found using rqg with following command line (does not repeat every time):
perl ./runall-new.pl --grammar=conf/engines/engine_stress.yy --gendata=conf/engi
|
nes/engine_stress.zz --duration=2000 --queries=100M --threads=8 --galera=mmm --b
|
asedir=/home/jan/mysql/10.0-galera --vardir=/home/jan/mysql/galera-test "--mysql
|
d=--wsrep-provider=/usr/lib/libgalera_smm.so" "--mysqld=--wsrep_sst_method=rsync"
|
ddd stack trace:
(gdb) where
|
#0 0x00007fc6e8fd6621 in __pthread_kill (threadid=<optimized out>, signo=6) at ../nptl/sysdeps/unix/sysv/linux/pthread_kill.c:61
|
#1 0x0000000000ea285b in my_write_core (sig=6) at /home/jan/mysql/10.0-galera/mysys/stacktrace.c:457
|
#2 0x00000000008979f6 in handle_fatal_signal (sig=6) at /home/jan/mysql/10.0-galera/sql/signal_handler.cc:262
|
#3 <signal handler called>
|
#4 0x00007fc6e842bbb9 in __GI_raise (sig=sig@entry=6) at ../nptl/sysdeps/unix/sysv/linux/raise.c:56
|
#5 0x00007fc6e842efc8 in __GI_abort () at abort.c:89
|
#6 0x0000000000c27ce8 in lock_get_first_lock (ctx=0x7fc6e80ff300, heap_no=0x7fc6e80ff2a8) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:4033
|
#7 0x0000000000c28742 in lock_deadlock_search (ctx=0x7fc6e80ff300, waitee_ptr=0x0) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:4303
|
#8 0x0000000000c28c92 in lock_deadlock_check_and_resolve (lock=0x7fc6ac46f738, trx=0x7fc6ac47e678) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:4467
|
#9 0x0000000000c243ff in lock_rec_enqueue_waiting (c_lock=0x7fc6ac071120, type_mode=1027, block=0x7fc6befca1d0, heap_no=71, index=0x7fc6d91b4ff8, thr=0x7fc6ad597780) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:2259
|
#10 0x0000000000c25000 in lock_rec_lock_slow (impl=0, mode=1027, block=0x7fc6befca1d0, heap_no=71, index=0x7fc6d91b4ff8, thr=0x7fc6ad597780) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:2602
|
#11 0x0000000000c252af in lock_rec_lock (impl=0, mode=1027, block=0x7fc6befca1d0, heap_no=71, index=0x7fc6d91b4ff8, thr=0x7fc6ad597780) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:2670
|
#12 0x0000000000c2f32f in lock_clust_rec_read_check_and_lock (flags=0, block=0x7fc6befca1d0, rec=0x7fc6c6b28dc9 "\200", index=0x7fc6d91b4ff8, offsets=0x7fc6e80ff880, mode=LOCK_X, gap_mode=1024, thr=0x7fc6ad597780) at /home/jan/mysql/10.0-galera/storage/xtradb/lock/lock0lock.cc:7028
|
#13 0x0000000000cf4d27 in sel_set_rec_lock (block=0x7fc6befca1d0, rec=0x7fc6c6b28dc9 "\200", index=0x7fc6d91b4ff8, offsets=0x7fc6e80ff880, mode=3, type=1024, thr=0x7fc6ad597780) at /home/jan/mysql/10.0-galera/storage/xtradb/row/row0sel.cc:1011
|
#14 0x0000000000cfb432 in row_search_for_mysql (buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>, mode=1, prebuilt=0x7fc6ad597078, match_mode=0, direction=1) at /home/jan/mysql/10.0-galera/storage/xtradb/row/row0sel.cc:4513
|
#15 0x0000000000bd286c in ha_innobase::general_fetch (this=0x7fc6ad55e088, buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>, direction=1, match_mode=0) at /home/jan/mysql/10.0-galera/storage/xtradb/handler/ha_innodb.cc:9515
|
#16 0x0000000000bd2dc2 in ha_innobase::rnd_next (this=0x7fc6ad55e088, buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>) at /home/jan/mysql/10.0-galera/storage/xtradb/handler/ha_innodb.cc:9732
|
#17 0x000000000089db32 in handler::ha_rnd_next (this=0x7fc6ad55e088, buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>) at /home/jan/mysql/10.0-galera/sql/handler.cc:2617
|
#18 0x0000000000e6b464 in ha_partition::rnd_next (this=0x7fc6ad4ee888, buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>) at /home/jan/mysql/10.0-galera/sql/ha_partition.cc:4910
|
#19 0x000000000089db32 in handler::ha_rnd_next (this=0x7fc6ad4ee888, buf=0x7fc6ad44d3a0 "\377", ' ' <repeats 12 times>) at /home/jan/mysql/10.0-galera/sql/handler.cc:2617
|
#20 0x00000000008935ca in find_all_keys (param=0x7fc6e81005b0, select=0x7fc6ac423b00, fs_info=0x7fc6e8100540, buffpek_pointers=0x7fc6e81007d0, tempfile=0x7fc6e8100630, pq=0x0, found_rows=0x7fc6e8100a80) at /home/jan/mysql/10.0-galera/sql/filesort.cc:757
|
#21 0x0000000000891fff in filesort (thd=0x7fc6bd633070, table=0x7fc6ad4d0470, sortorder=0x7fc6ac4a1088, s_length=5, select=0x7fc6ac423b00, max_rows=18446744073709551615, sort_positions=true, examined_rows=0x7fc6e8100a60, found_rows=0x7fc6e8100a80) at /home/jan/mysql/10.0-galera/sql/filesort.cc:299
|
#22 0x00000000009facb3 in mysql_delete (thd=0x7fc6bd633070, table_list=0x7fc6ac422370, conds=0x7fc6ac422e00, order_list=0x7fc6bd637900, limit=3, options=0, result=0x7fc6ac423748) at /home/jan/mysql/10.0-galera/sql/sql_delete.cc:484
|
#23 0x00000000006833ed in mysql_execute_command (thd=0x7fc6bd633070) at /home/jan/mysql/10.0-galera/sql/sql_parse.cc:3931
|
#24 0x000000000068c909 in mysql_parse (thd=0x7fc6bd633070, rawbuf=0x7fc6ac422088 "DELETE LOW_PRIORITY IGNORE FROM `table100_key_pk_parts_2_int_autoinc` WHERE `col_int_key` IN ( 28 , 155 , 4 , 9 , 'f' ) ORDER BY `col_char_12`,`col_char_12_key`,`col_int`,`col_int_key`,`pk` LIMIT 3", length=198, parser_state=0x7fc6e8102220) at /home/jan/mysql/10.0-galera/sql/sql_parse.cc:7010
|
#25 0x000000000068c07a in wsrep_mysql_parse (thd=0x7fc6bd633070, rawbuf=0x7fc6ac422088 "DELETE LOW_PRIORITY IGNORE FROM `table100_key_pk_parts_2_int_autoinc` WHERE `col_int_key` IN ( 28 , 155 , 4 , 9 , 'f' ) ORDER BY `col_char_12`,`col_char_12_key`,`col_int`,`col_int_key`,`pk` LIMIT 3", length=198, parser_state=0x7fc6e8102220) at /home/jan/mysql/10.0-galera/sql/sql_parse.cc:6832
|
#26 0x000000000067d0b4 in dispatch_command (command=COM_QUERY, thd=0x7fc6bd633070, packet=0x7fc6bd639071 "DELETE LOW_PRIORITY IGNORE FROM `table100_key_pk_parts_2_int_autoinc` WHERE `col_int_key` IN ( 28 , 155 , 4 , 9 , 'f' ) ORDER BY `col_char_12`,`col_char_12_key`,`col_int`,`col_int_key`,`pk` LIMIT 3", packet_length=198) at /home/jan/mysql/10.0-galera/sql/sql_parse.cc:1485
|
#27 0x000000000067bda8 in do_command (thd=0x7fc6bd633070) at /home/jan/mysql/10.0-galera/sql/sql_parse.cc:1087
|
#28 0x00000000007a6f4c in do_handle_one_connection (thd_arg=0x7fc6bd633070) at /home/jan/mysql/10.0-galera/sql/sql_connect.cc:1396
|
#29 0x00000000007a6ca4 in handle_one_connection (arg=0x7fc6bd633070) at /home/jan/mysql/10.0-galera/sql/sql_connect.cc:1307
|
#30 0x00007fc6e8fd1182 in start_thread (arg=0x7fc6e8103700) at pthread_create.c:312
|
#31 0x00007fc6e84effbd in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111
|
Attachments
Issue Links
- relates to
-
MDEV-6564 BF-BF X lock conflict
-
- Closed
-
-
MDEV-10544 Galera: Failing assertion: (lock->trx)->wait_lock == lock
-
- Closed
-
InnoDB transaction log:
=====================================
141003 16:21:20 INNODB MONITOR OUTPUT
=====================================
Per second averages calculated from the last 20 seconds
-----------------
BACKGROUND THREAD
-----------------
srv_master_thread loops: 872 1_second, 872 sleeps, 78 10_second, 95 background, 95 flush
srv_master_thread log flush and writes: 2095
----------
SEMAPHORES
----------
OS WAIT ARRAY INFO: reservation count 3244, signal count 3213
Mutex spin waits 1154, rounds 96727, OS waits 3089
RW-shared spins 108, rounds 2575, OS waits 80
RW-excl spins 6, rounds 2145, OS waits 65
Spin rounds per wait: 83.82 mutex, 23.84 RW-shared, 357.50 RW-excl
--------
FILE I/O
--------
I/O thread 0 state: waiting for completed aio requests (insert buffer thread)
I/O thread 1 state: waiting for completed aio requests (log thread)
I/O thread 2 state: waiting for completed aio requests (read thread)
I/O thread 3 state: waiting for completed aio requests (read thread)
I/O thread 4 state: waiting for completed aio requests (read thread)
I/O thread 5 state: waiting for completed aio requests (read thread)
I/O thread 6 state: waiting for completed aio requests (write thread)
I/O thread 7 state: waiting for completed aio requests (write thread)
I/O thread 8 state: waiting for completed aio requests (write thread)
I/O thread 9 state: waiting for completed aio requests (write thread)
Pending normal aio reads: 0 [0, 0, 0, 0] , aio writes: 0 [0, 0, 0, 0] ,
ibuf aio reads: 0, log i/o's: 0, sync i/o's: 0
Pending flushes (fsync) log: 0; buffer pool: 0
284 OS file reads, 4958 OS file writes, 1823 OS fsyncs
0.00 reads/s, 0 avg bytes/read, 0.00 writes/s, 0.00 fsyncs/s
-------------------------------------
INSERT BUFFER AND ADAPTIVE HASH INDEX
-------------------------------------
Ibuf: size 1, free list len 0, seg size 2, 0 merges
merged operations:
insert 0, delete mark 0, delete 0
discarded operations:
insert 0, delete mark 0, delete 0
Hash table size 276671, node heap has 2 buffer(s)
0.00 hash searches/s, 0.00 non-hash searches/s
---
LOG
---
Log sequence number 2735953
Log flushed up to 2735953
Last checkpoint at 2735953
Max checkpoint age 7782360
Checkpoint age target 7539162
Modified age 0
Checkpoint age 0
0 pending log writes, 0 pending chkp writes
1654 log i/o's done, 0.00 log i/o's/second
----------------------
BUFFER POOL AND MEMORY
----------------------
Total memory allocated 137756672; in additional pool allocated 0
Total memory allocated by read views 760
Internal hash tables (constant factor + variable factor)
Adaptive hash index 2250352 (2213368 + 36984)
Page hash 139112 (buffer pool 0 only)
Dictionary cache 717229 (554768 + 162461)
File system 83536 (82672 + 864)
Lock system 344944 (332872 + 12072)
Recovery system 0 (0 + 0)
Dictionary memory allocated 162461
Buffer pool size 8191
Buffer pool size, bytes 134201344
Free buffers 7745
Database pages 444
Old database pages 0
Modified db pages 0
Pending reads 0
Pending writes: LRU 0, flush list 0, single page 0
Pages made young 0, not young 0
0.00 youngs/s, 0.00 non-youngs/s
Pages read 145, created 299, written 3199
0.00 reads/s, 0.00 creates/s, 0.00 writes/s
No buffer pool page gets since the last printout
Pages read ahead 0.00/s, evicted without access 0.00/s, Random read ahead 0.00/s
LRU len: 444, unzip_LRU len: 0
I/O sum[0]:cur[0], unzip sum[0]:cur[0]
--------------
ROW OPERATIONS
--------------
0 queries inside InnoDB, 0 queries in queue
2 read views open inside InnoDB
5 transactions active inside InnoDB
5 out of 1000 descriptors used
---OLDEST VIEW---
Normal read view
Read view low limit trx n:o B2F
Read view up limit trx id AE4
Read view low limit trx id B2F
Read view individually stored trx ids:
Read view trx id B2E
Read view trx id B2D
Read view trx id B29
Read view trx id B1B
Read view trx id B02
Read view trx id AFF
Read view trx id AE4
-----------------
Main thread process no. 22083, id 140206485255936, state: waiting for server activity
Number of rows inserted 1650, updated 1450, deleted 491, read 45755
0.00 inserts/s, 0.00 updates/s, 0.00 deletes/s, 0.00 reads/s
------------------------
LATEST DETECTED DEADLOCK
------------------------
141003 13:41:06
*** (1) TRANSACTION:
TRANSACTION B1B, ACTIVE 306 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 13 lock struct(s), heap size 3112, 5 row lock(s), undo log entries 3
MySQL thread id 9, OS thread handle 0x7f849059a700, query id 2846 localhost 127.0.0.1 root init
DELETE LOW_PRIORITY QUICK IGNORE FROM `table2_int_autoinc` ORDER BY `col_char_12`,`col_char_12_key`,`col_int`,`col_int_key`,`pk` LIMIT 2
*** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 0 page no 334 n bits 184 index `PRIMARY` of table `test`.`table2_int_autoinc` trx id B1B lock_mode X locks rec but not gap waiting
*** (2) TRANSACTION:
TRANSACTION AFF, ACTIVE 611 sec fetching rows
mysql tables in use 4, locked 4
32 lock struct(s), heap size 6960, 123 row lock(s), undo log entries 6
MySQL thread id 8, OS thread handle 0x7f8491c67700, query id 2849 localhost 127.0.0.1 root executing
DELETE LOW_PRIORITY FROM `table1_key_pk_parts_2_int_autoinc` WHERE `col_char_12_key` IN ( SELECT `col_char_12_key` FROM `table2_key_pk_parts_2_int_autoinc` WHERE `pk` = 2 ) ORDER BY `col_char_12`,`col_char_12_key`,`col_int`,`col_int_key`,`pk` LIMIT 2
*** (2) HOLDS THE LOCK(S):
RECORD LOCKS space id 0 page no 334 n bits 176 index `PRIMARY` of table `test`.`table2_int_autoinc` trx id AFF lock_mode X locks rec but not gap
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 0 page no 329 n bits 144 index `PRIMARY` of table `test`.`table1_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id AFF lock_mode X locks rec but not gap waiting
*** WE ROLL BACK TRANSACTION (1)
------------
TRANSACTIONS
------------
Trx id counter B37
Purge done for trx's n:o < B28 undo n:o < 0
History list length 211
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION B2F, ACTIVE 9736 sec
mysql tables in use 2, locked 2
2 lock struct(s), heap size 376, 1 row lock(s), undo log entries 1
MySQL thread id 12, OS thread handle 0x7f84904bf700, query id 2829 localhost 127.0.0.1 root query end
INSERT LOW_PRIORITY INTO `table0_key_pk_parts_2_int_autoinc` (`pk`) VALUES (NULL)
TABLE LOCK table `test`.`table0_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B2F lock mode IX
RECORD LOCKS space id 0 page no 315 n bits 152 index `PRIMARY` of table `test`.`table0_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B2F lock_mode X locks rec but not gap
---TRANSACTION B2E, ACTIVE 9767 sec
mysql tables in use 1, locked 1
1 lock struct(s), heap size 376, 0 row lock(s), undo log entries 1
MySQL thread id 14, OS thread handle 0x7f848f1f6700, query id 2826 localhost 127.0.0.1 root query end
REPLACE LOW_PRIORITY INTO `table100_int_autoinc` (`pk`) VALUES (NULL)
TABLE LOCK table `test`.`table100_int_autoinc` trx id B2E lock mode IX
---TRANSACTION B29, ACTIVE 9818 sec starting index read
mysql tables in use 2, locked 2
LOCK WAIT 3 lock struct(s), heap size 1248, 3 row lock(s), undo log entries 2
MySQL thread id 2, OS thread handle 0x7f8491d9b700, query id 2808 Update_rows_log_event::find_row(783)
------- TRX HAS BEEN WAITING 9818 SEC FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 0 page no 373 n bits 248 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B29 lock_mode X locks rec but not gap waiting
------------------
TABLE LOCK table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B29 lock mode IX
RECORD LOCKS space id 0 page no 373 n bits 248 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B29 lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 373 n bits 248 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B29 lock_mode X locks rec but not gap waiting
---TRANSACTION B1B, ACTIVE 9920 sec
16 lock struct(s), heap size 3112, 5 row lock(s), undo log entries 3
MySQL thread id 9, OS thread handle 0x7f849059a700, query id 2887 localhost 127.0.0.1 root sleeping
COMMIT
Trx read view will not see trx with id >= B30, sees < AE4
TABLE LOCK table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock mode IX
RECORD LOCKS space id 0 page no 371 n bits 128 index `col_int_key` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 368 n bits 120 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock_mode X locks rec but not gap
TABLE LOCK table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B1B lock mode IX
RECORD LOCKS space id 0 page no 375 n bits 176 index `col_int_key` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B1B lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 373 n bits 248 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B1B lock_mode X locks rec but not gap
TABLE LOCK table `test`.`table1_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock mode IX
TABLE LOCK table `test`.`table10_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock mode IX
RECORD LOCKS space id 0 page no 355 n bits 112 index `col_char_12_key` of table `test`.`table10_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id B1B lock_mode X locks rec but not gap
TABLE LOCK table `test`.`table1_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id B1B lock mode IX
TOO MANY LOCKS PRINTED FOR THIS TRX: SUPPRESSING FURTHER PRINTS
---TRANSACTION AE4, ACTIVE 10276 sec
31 lock struct(s), heap size 6960, 247 row lock(s), undo log entries 26
MySQL thread id 11, OS thread handle 0x7f8490508700, query id 2825 localhost 127.0.0.1 root sleeping
COMMIT
TABLE LOCK table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock mode IX
RECORD LOCKS space id 0 page no 341 n bits 112 index `col_int_key` of table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 339 n bits 144 index `PRIMARY` of table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock_mode X locks rec but not gap
TABLE LOCK table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id AE4 lock mode IX
RECORD LOCKS space id 0 page no 345 n bits 112 index `col_int_key` of table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id AE4 lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 343 n bits 144 index `PRIMARY` of table `test`.`table2_key_pk_parts_2_int_autoinc` /* Partition `p1` */ trx id AE4 lock_mode X locks rec but not gap
TABLE LOCK table `test`.`table0_int_autoinc` trx id AE4 lock mode IX
TABLE LOCK table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock mode IX
RECORD LOCKS space id 0 page no 371 n bits 128 index `col_int_key` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock_mode X locks rec but not gap
RECORD LOCKS space id 0 page no 368 n bits 120 index `PRIMARY` of table `test`.`table100_key_pk_parts_2_int_autoinc` /* Partition `p0` */ trx id AE4 lock_mode X locks rec but not gap
TOO MANY LOCKS PRINTED FOR THIS TRX: SUPPRESSING FURTHER PRINTS
----------------------------
END OF INNODB MONITOR OUTPUT
============================
WSREP: BF lock wait long