死锁和死锁检测

摘要:
事务A等待事务B释放id=2的锁,事务B等待事务A释放id=1的锁。有两种方法可以解决死锁和死锁问题。1.直接输入wait,超时可以通过innodb参数_ lock_ wait_timeout来确定。2.启动死锁检测。主动回滚死锁链中的事务。第一个锁定线程将在50秒后退出,然后其他线程可以继续执行。这是正常的锁等待,这会导致很多人受伤。因此,我们最好使用死锁检测。

死锁和死锁检测第1张

如图所示,事务A在等待事务B释放id=2的锁,事务B在等待事务A释放id=1的锁

这种情况就是死锁

发生死锁有两种方法解决

1.直接进入等待,直到超时。这个超时时间可以通过参数innodb_lock_wait_timeout来设置

2.发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以执行。

   将参数innodb_deadlock_detect设置为on,表示开启这个逻辑

在innodb中,innodb_lock_wait_timeout的值默认是50s,以为着如果使用第一种方法,

第一个被锁住的线程要过50s才会超时退出,然后其他线程才有可能继续执行。

对于在线服务来说,这个等待时间往往是无法接受的。

但是我们又不能把这个时间设置的很小,比如1s,如果这个时候不是死锁,而是正常的锁等待呢

这样就会造成很多误伤,所以我们还是使用死锁检测好一些,好在innodb_deadlock_detect默认就是on

其实死锁检测也是会占用很多cpu资源的,当事务被锁住的时候,就要看看它锁依赖的线程有没有被别人锁住

如此循环,最后判断是否出现了循环等待,也就是死锁

免责声明:文章转载自《死锁和死锁检测》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇HDMIscapy的安装下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

jdbc 连接数据库

1.什么是jdbc? 答:jdbc是java data base connection 的简写,即java与数据库的连接,是java与数据库之间进行数据交互的工具,书上解释为java访问数据库的API。jdbc是一个轻量级的连接封装,适用于多种数据库,如:oracle、sql server,mysql等等。hibernate则是对jdbc的再封装。 2、j...

TransactionScope使用说明 【转】

TransactionScope是.Net Framework 2.0滞后,新增了一个名称空间。它的用途是为数据库访问提供了一个“轻量级”[区别于:SqlTransaction]的事物。使用之前必须添加对 System.Transactions.dll 的引用。        下列代码就是一个正在创建的事务,这个事务自身还封装了多个数据库查询。只要任意一个...

C#图解教程 第二十章 异步编程

笔记 异步编程 什么是异步 示例 async/await特性的结构什么是异步方法 异步方法的控制流await表达式取消一个异步操作异常处理和await表达式在调用方法中同步地等待任务在异步方法中异步地等待任务Task.Delay方法 在GUI程序中执行异步操作 Task.Yield 使用异步Lambda表达式完整的GUI程序BackgroundW...

Java事务

Java事务的类型有三种:JDBC事务、JTA(Java Transaction API)事务、容器事务。常见的容器事务如Spring事务,容器事务主要是J2EE应用服务器提供的,容器事务大多是基于JTA完成,这是一个基于JNDI的,相当复杂的API实现。所以本文暂不讨论容器事务。本文主要介绍J2EE开发中两个比较基本的事务:JDBC事务和JTA事务。 J...

(翻译)Entity Framework技巧系列之九 Tip 35 36

提示35. 怎样实现OfTypeOnly<TEntity>()这样的写法 如果你编写这样LINQ to Entities查询: 1 var results = from c in ctx.Vehicles.OfType<Car>() 2 select c; 这会返回,Cars包括那些派生自Car类型,如...

Android 通知栏Notification的整合 全面学习 (一个DEMO让你完全了解它)

在android的应用层中,涉及到很多应用框架,例如:Service框架,Activity管理机制,Broadcast机制,对话框框架,标题栏框架,状态栏框架,通知机制,ActionBar框架等等。 下面就来说说经常会使用到通知机制中的通知栏框架(Notificaiton),它适用于交互事件的通知。它是位于顶层可以展开的通知列表。它会时不时的提醒你什么软件...