14.5.5.3 How to Minimize and Handle Deadlocks  如何减少和处理死锁

这个部分建立在概念信息关于deadlocks 在章节 14.5.5.2, “Deadlock Detection and Rollback”. 

它解释了如何组织数据库操作来减少死锁和随后的错误处理

Deadlocks  是一个经典的问题 在事务性数据库,但是他们不是危险的 除非它们是如此频繁你根本不能运行某个事务。

通常情况下,你必须写你的应用以便他们总是准备重新执行一个事务 如果由于死锁被回滚

InnoDB 使用自动行锁,你可以得到死锁 甚至在只有插入和删除单条记录的情况。

那是因为那些操作不是真正的原子的,他们自动设置锁在(可能的多个)index records上

你能处理死锁和降低他们的发生的可能性使用下面的技术:

1.在任何时候,执行SHOW ENGINE INNODB STATUS命令来确定最近的死锁的原因。那个可以帮助你调整你的应用来避免死锁:

2.如果频繁的死锁警告导致顾虑,收集更多的调试信息通过启用 innodb_print_all_deadlocks  配置选项,

信息关于每个死锁,不只是最新的,是被记录在MySQL error log. 

3.总是准备重新执行一个事务 如果它回滚由于死锁,Deadlocks 不是危险的,只需要重新尝试

4. 让事务小的和短的让它们不易冲突

5. 在做了一组相关的改变立即提交让他们不易发生冲突。

特别的, 不要把一个活动的mysql session 保持open 对于一个长时间允许的未提交的事务

如果你使用锁定读(SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE),  尝试使用较低的隔离级别 比如READ COMMITTED.

6.当修改多个表在一个事务里,或者不同的行集在相同的表,

做这些操作在一个一致性的顺序。

然后事务形成良好定义的队列,不会死锁。

7.增加好的索引到你的表, 然后呢查询需要扫描很少的记录,从而设置更少的锁

使用 EXPLAIN SELECT 来确定哪个index 你的查询在使用

8.使用较少的锁,如果你可以负担允许一个SELECT 返回记录从一个老的快照,

不要增加FOR UPDATE or LOCK IN SHARE MODE子句。

使用 READ COMMITTED 隔离级别是好的在这里,因为每个一致性读在相同的事务 读取他自己的最新的快照

9.如果没有其他的帮助, 序列化你的事务使用表级锁。

正确的方式是使用LOCK TABLES,比如InnoDB 表,开始事务设置autocommit = 0

14.5.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁的更多相关文章

  1. 14.3.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁

    14.3.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁 这个章节建立关于死锁的概念信息,它解释如何组织数据库操作来减少死锁和随后的错误处理: D ...

  2. [LeetCode] 924. Minimize Malware Spread 最大程度上减少恶意软件的传播

    In a network of nodes, each node i is directly connected to another node j if and only if graph[i][j ...

  3. 14.5.5 Deadlocks in InnoDB

    14.5.5 Deadlocks in InnoDB 14.5.5.1 An InnoDB Deadlock Example 14.5.5.2 Deadlock Detection and Rollb ...

  4. 14.3.5.1 An InnoDB Deadlock Example

    14.3.5 Deadlocks in InnoDB 14.3.5.1 An InnoDB Deadlock Example 14.3.5.2 Deadlock Detection and Rollb ...

  5. MySQL error : Deadlock found when trying to get lock; try restarting transaction

    在使用 MySQL 时,我们有时会遇到这样的报错:“Deadlock found when trying to get lock; try restarting transaction”. 在 14. ...

  6. (转)雅虎WEB前端网站优化 -- 34条军规

    雅虎给出了优化网站加载速度的34条法则(包括Yslow规则22条) 详细说明,下载转发 ponytail 的译文(来自帕兰映像). 1.Minimize HTTP Requests 减少HTTP请求 ...

  7. 雅虎WEB前端网站优化 -- 34条军规

    雅虎给出了优化网站加载速度的34条法则(包括Yslow规则22条) 详细说明,下载转发 ponytail 的译文(来自帕兰映像). 1.Minimize HTTP Requests 减少HTTP请求 ...

  8. Effective Objective-C [上]

    网上看到的 http://esoftmobile.com/2013/08/10/effective-objective-c/ 本文是针对<Effective Objective-C>一书的 ...

  9. Yahoo34条军规——雅虎WEB前端网站优化

    雅虎给出了优化网站加载速度的34条法则(包括Yslow规则22条) 详细说明,下载转发 ponytail 的译文(来自帕兰映像). 1.Minimize HTTP Requests 减少HTTP请求 ...

随机推荐

  1. build/envsetup.sh中hmm、get_abs_build_var、get_build_var解析

    function hmm() { # 打印帮助信息 cat <<EOF Invoke ". build/envsetup.sh" from your shell to ...

  2. [序列化] SerializeHelper--序列化操作帮助类 (转载)

    点击下载 SerializeHelper.zip 这个类是关于加密,解密的操作,文件的一些高级操作1.XML序列化2.Json序列化3.SoapFormatter序列化4.BinaryFormatte ...

  3. SVN配置使用

    文档规则 [本地工作区] :work copy ,本地工作副本: [主项目]:引用共用模块的新项目(工程) 最新版本(HEAD revision):版本库里文件或目录的最新版本 SA :SVN服务器的 ...

  4. Android- Context理解

    学习了安卓以后还是不理解Context的用法:Api文档链接http://wear.techbrood.com/reference/android/content/Context.html 一个非常好 ...

  5. proxy.ini文件调用

    self.CONFIG_FILENAME = os.path.splitext(os.path.abspath(__file__))[0]+'.ini' 改为: self.CONFIG_FILENAM ...

  6. jquery table的隔行变色 鼠标事件

    一.鼠标事件 mouseover(function(){}); 鼠标移动到目标事件 mouseout(function(){}); 鼠标离开目标的事件 二.具体应用代码 <body> &l ...

  7. Twisted介绍

    Twisted诞生于2000年初,作者为Glyph,目的是为了开发网络游戏. Twisted的历史 Glyph开始采用Java多线程,来开发Twisted Reality,结果多线程使得开发变得复杂, ...

  8. gif图简介

    多媒体教程 - GIF 图 GIF 是在 Web 上使用的主要图像格式之一. 本文详细讲解了 GIF 图像的特性和使用技巧. 理解图像格式 无论是 HTML 还是 XHTML 都没有规定图像的官方格式 ...

  9. PC110304/UVA850

    这题目WA了好几次,主要是我没有理解清楚No solution.这个情况. 如果在match原文做好了,基本map一下就能过了. 与原句match的条件就是: 1.出现了26个字母 2.该空格的地方要 ...

  10. Win32中GDI+应用(四)--- 位图的打开与显示

    显示位图,你应该使用GDI+里面的Bitmap类或者Image类,这两个类都提供了方法从硬盘上的一个文件打开文件,创建相应的内存中的位图对象的工作.然后你可以使用Graphics类的DrawImage ...