- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在MySQL 5.7.18中我有一个名为“test”的表,定义如下:
| test | CREATE TABLE `test` (
`id` varchar(255) NOT NULL,
`name` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `test_name_x01` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
它只有 1 行:
id | name
2 | eva
现在我启动 2 个事务,均处于 REPEATABLE-READ 隔离级别,并执行如下命令:
------------------------
LATEST DETECTED DEADLOCK
------------------------
2017-05-06 20:24:28 0x126df8000
*** (1) TRANSACTION:
TRANSACTION 112142, ACTIVE 15 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 2 lock struct(s), heap size 1136, 1 row lock(s)
MySQL thread id 139, OS thread handle 4950491136, query id 997169 localhost root Sending data
select * from test where name='eva' for update
*** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 26 page no 5 n bits 72 index test_name_x01 of table `promotion`.`test` trx id 112142 lock_mode X waiting
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
0: len 3; hex 657661; asc eva;;
1: len 1; hex 32; asc 2;;
*** (2) TRANSACTION:
TRANSACTION 112141, ACTIVE 19 sec inserting
mysql tables in use 1, locked 1
4 lock struct(s), heap size 1136, 4 row lock(s), undo log entries 1
MySQL thread id 138, OS thread handle 4947148800, query id 997170 localhost root update
insert into test values (1, 'eva')
*** (2) HOLDS THE LOCK(S):
RECORD LOCKS space id 26 page no 5 n bits 72 index test_name_x01 of table `promotion`.`test` trx id 112141 lock_mode X
Record lock, heap no 1 PHYSICAL RECORD: n_fields 1; compact format; info bits 0
0: len 8; hex 73757072656d756d; asc supremum;;
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
0: len 3; hex 657661; asc eva;;
1: len 1; hex 32; asc 2;;
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 26 page no 5 n bits 72 index test_name_x01 of table `promotion`.`test` trx id 112141 lock_mode X locks gap before rec insert intention waiting
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
0: len 3; hex 657661; asc eva;;
1: len 1; hex 32; asc 2;;
*** WE ROLL BACK TRANSACTION (1)
根据我的研究,以下是我认为可能导致死锁的原因。但需要专业人士确认。
1. T1 : begin;
2. T2 : begin;
3. T2 : select * from test where name='eva' for update;
第 3 步需要:IX 锁,索引“name”上的下一键锁(负无穷大,“eva”]
4. T1 : select * from test where name='eva' for update;
第 4 步需要:IX 锁,索引“name”上的下一个键锁(负无穷大,“eva”)IX锁与IX兼容,因此T1无需T2释放即可获取它。next-key lock 实际上包含 2 个部分:记录 X + 间隙,由于冲突的锁可以被不同的事务持有在间隙上,所以 T1 也持有间隙锁而不等待 T2。 所以 T1 只是等待T2 释放记录锁(在二级索引 name='eva' 和聚集索引 id='1' 上)以继续。
5. T2 : insert into test values (1, 'eva'); (dead lock, T1 is rolled back)
第5步:这里插入需要插入意图锁,这与间隙锁不兼容。因此T2正在等待T1释放其间隙锁。但同时T1正在等待T2释放记录X锁。
================================================== =========================
此外,对于第 5 步,在尝试使用不同的 ID 值后,我得到以下观察结果:
如果表预加载了具有不同 ID 且名称相同“eva”的多行,只有在步骤 5 中尝试插入的 ID 值小于所有现有行的最小 ID 时,才会重现死锁。
例如预加载表
id | name
2 | eva
4 | eva
对于上面的步骤 5,
insert (0, 'eva') => deadlock
insert (1, 'eva') => deadlock
insert (3, 'eva') => NO deadlock
insert (5, 'eva') => NO deadlock
最佳答案
请勿将数字存储到不带引号的 VARCHAR
中。这会挫败任何使用索引的尝试。
更多
一般来说,...
当可以通过索引识别单行时,只有该行将被“锁定”。单行锁定通常通过“延迟”一个事务直到另一个事务释放其锁来避免死锁。
当必须扫描整个表时,所有行可能需要锁定。这可能不允许“延迟”,并陷入僵局。
无论如何,...
通过准备好重放整个事务来计划死锁。 有些死锁是不可避免的。
(很抱歉含糊其词;这里有太多可能的变化。修复引号或索引;应该避免大多数死锁。)
关于MySQL InnoDB select for update 和 insert 之间出现死锁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43827740/
我有类似下面的代码: ... id: myComponent signal updateState() property variant modelList: [] Repeater { mo
我正在处理一些我无法展示的私有(private)代码,但我已经制作了一些示例代码来描述我的问题: 主.c: #include #include #include #include typede
这个问题在这里已经有了答案: 关闭10 年前。 Possible Duplicate: what are the differences in die() and exit() in PHP? 我想
在编写 Perl 模块时,在模块内部使用 croak/die 是一个好习惯吗? 毕竟,如果调用者不使用 eval block ,模块可能会使调用它的程序崩溃。 在这些情况下,最佳做法是什么? 最佳答案
我有一些搜索线程正在存储结果。我知道当线程启动时,JVM native 代码会代理在操作系统上创建新 native 线程的请求。这需要 JVM 之外的一些内存。当线程终止并且我保留对它的引用并将其用作
我刚刚花了很多时间调试一个我追溯到 wantarray() 的问题。 .我已将其提炼为这个测试用例。 (忽略 $! 在这种情况下不会有任何有用信息的事实)。我想知道为什么wantarray在第二个示例
我看到一些代码是这样做的: if(something){ echo 'exit from program'; die; } ...more code 和其他只使用 die 的人: if
我正在尝试将此表格用于: 如果任何 $_POST 变量等于任何其他 $_POST 变量抛出错误。 如果只有几个,那不是问题,但我有大约 20 个左右所以如果我想这样做,我将不得不像这样 但这
每次我运行: hadoop dfsadmin -report 我得到以下输出: Configured Capacity: 0 (0 KB) Present Capacity: 0 (0 KB) DFS
我是一名优秀的程序员,十分优秀!