- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我无法重现或诊断来自 MySQL 的“超出锁定等待超时”错误。我确定它是死锁(而不是事务获取锁然后摆弄它的拇指),因为我的日志显示另一个进程同时启动,也挂起,然后在第一次超时时继续。但通常情况下,InnoDB 会在没有超时的情况下检测到死锁。所以我试图理解为什么没有检测到这个死锁。
两个事务都使用可序列化的隔离级别。 (我对这个隔离级别的 InnoDB 锁定有一个很好的理解。)事务中使用了一个非 InnoDB (MyISAM) 表,我将其插入并更新。但是,我不明白它是如何参与死锁的,因为我相信 MyISAM 只是在插入和更新期间获取表锁(然后立即释放它,因为 MyISAM 不是事务性的),所以在此期间没有其他锁被获取持有表锁。
所以我确信死锁只涉及 InnoDB 表,这让我回到了为什么没有检测到死锁的问题。 MySQL 文档 (http://dev.mysql.com/doc/refman/5.1/en/innodb-deadlock-detection.html) 暗示死锁检测几乎总是有效。我在搜索时发现的问题案例涉及诸如显式“锁定表”、“更改表”和“延迟插入”之类的事情。我没有做任何这些事情,只是插入、更新和选择(我的一些选择是“用于更新”)。
我试图通过创建一个 MyISAM 表和几个 InnoDB 表并在 MyISAM 中执行各种插入和更新序列,以及在 InnoDB 中“选择更新”来重现。但每次我产生死锁时,InnoDB 都会立即报告。我无法重现超时。
还有其他诊断此问题的提示吗?我正在使用 mysql 5.1.49。
最佳答案
一个技巧是您可以使用 SHOW INNODB STATUS
来显示 InnoDB 引擎的状态。
它返回的信息(一大堆文本)包括当前表锁的信息,以及最后检测到的死锁(在标题 "LATEST DETECTED DEADLOCK"
下),所以这个技巧不是这在事后很有用,但它可以帮助您在挂起的查询发生时对其进行跟踪。
mysqladmin debug
还可以打印有用的锁定调试信息。
第三个技巧是创建一个名为 innodb_lock_monitor
的神奇命名表,如 http://dev.mysql.com/doc/refman/5.1/en/innodb-monitors.html 中所述。这提供了更详细的锁调试。
喂!
更新:
它可能没有检测到死锁,因为它实际上不是死锁,但更有可能的是一个进程正在等待另一个进程锁定的行上的行锁。来自 innodb_lock_wait_timeout
的手册变量:
The timeout in seconds an InnoDB transaction may wait for a row lock before giving up. The default value is 50 seconds. A transaction that tries to access a row that is locked by another InnoDB transaction will hang for at most this many seconds before issuing the following error:
ERROR 1205 (HY000): Lock wait timeout
When a lock wait timeout occurs, the current statement is not executed. The current transaction is not rolled back. (Until MySQL 5.0.13 InnoDB rolled back the entire transaction if a lock wait timeout happened.
exceeded; try restarting transaction
死锁发生,例如,当两个进程各自需要锁定被另一个进程锁定的行时,再多的等待也无法解决冲突。
关于mysql - InnoDB什么时候超时而不是报死锁?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3808986/
一、公平锁和非公平锁 1.1、公平锁和非公平锁的概述 公平锁:指多个线程按照申请锁的顺序来获取锁。 非公平锁:指在多线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取到锁
阅读目录 1、简介 2、分类 3、全局锁 4、表级锁 5、表锁 6、元数据锁
因此,在我编写的程序中,我有三个函数,为了简单起见,我们将它们称为 A、B 和 C。每个函数都需要访问资源X才能工作。 限制是A和B不允许同时运行并且必须适当同步。但是,C 可以与 A 或 B 同时运
我听说过这些与并发编程相关的词,但是锁、互斥量和信号量之间有什么区别? 最佳答案 锁只允许一个线程进入被锁定的部分,并且该锁不与任何其他进程共享。 互斥锁与锁相同,但它可以是系统范围的(由多个进程共享
这个问题已经有答案了: What is an efficient way to implement a singleton pattern in Java? [closed] (29 个回答) 已关闭
这个问题已经有答案了: What is an efficient way to implement a singleton pattern in Java? [closed] (29 个回答) 已关闭
我对标题中的主题有几个问题。首先,假设我们使用 JDBC,并且有 2 个事务 T1 和 T2。在 T1 中,我们在一个特定的行上执行 select 语句。然后我们对该行执行更新。在事务 T2 中,我们
我希望我的函数只运行一次。这意味着如果多个线程同时调用它,该函数将阻塞所有线程,只允许它运行。 最佳答案 听起来您希望存储过程进行同步。为什么不直接将同步放在应用程序本身中。 pthread_mute
if (runInDemoMode) { lock (this) { //Initalization of tables dCreator.create
我相信无论使用什么语言都可以考虑我的问题,但是为了有一些“ anchor ”,我将使用 Java 语言来描述它。 让我们考虑以下场景:我有一个扩展 Thread 的类 PickyHost 及其实例 p
我知道异步不是并行的,但我现在遇到了一个非常有趣的情况。 async function magic(){ /* some processing here */ await async () =
我们正在使用 Scala、Play 框架和 MongoDB(以 ReactiveMongo 作为我们的驱动程序)构建一个网络应用程序。应用程序架构是端到端的非阻塞。 在我们代码的某些部分,我们需要访问
我需要一个简单的锁,JavaME 超时(concurrent.lock 的反向移植需要完整的 Java 1.3)。 如果其他人已经为 JavaME 发布了经过测试的锁定代码,我宁愿使用它。 锁定是出了
根据 boost : To access the object, a weak_ptr can be converted to a shared_ptr using the shared_ptr co
关于 Mutex 和 Critical 部分之间的区别存在一个问题,但它也不处理 Locks。 所以我想知道临界区是否可以用于进程之间的线程同步。 还有信号状态和非信号状态的含义 最佳答案 在 Win
锁 最为常见的应用就是 高并发的情况下,库存的控制。本次只做简单的单机锁介绍。 直接看代码: 每请求一次库存-1. 假如库存1000,在1000个人请求之后,库存将变为0。
线程和进程 1、线程共享创建它的进程的地址空间,进程有自己的地址空间 2、线程可以访问进程所有的数据,线程可以相互访问 3、线程之间的数据是独立的 4、子进程复制线程的数据 5、子进程启动
**摘要:**细心的你也一定关注到,有的网址是https开头的,有的是http。https开头的网站前面,会有一把小锁。这是为什么呢? 本文分享自华为云社区《还不知道SSL证书已经是刚需了?赶快来了解
试图在 C 中实现一个非常简单的互斥锁(锁)我有点困惑。我知道互斥锁类似于二进制信号量,除了互斥锁还强制执行释放锁的线程的约束,必须是最近获得它的同一线程。我对如何跟踪所有权感到困惑? 这是我到目前为
在阅读了很多与上述主题相关的文章和答案之后,我仍然想知道 SQL Server 数据库引擎在以下示例中是如何工作的: 假设我们有一个名为 t3 的表: create table t3 (a int ,
我是一名优秀的程序员,十分优秀!