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. Android(java)学习笔记174:SharedPreferences(轻量级存储类)

    1.SharedPreferences是Android平台上一个轻量级的存储类,简单的说就是可以存储一些我们需要的变量信息.2个activity 之间的数据传递除了可以他通过intent来传递数据,还 ...

  2. Android(java)学习笔记179:BroadcastReceiver之 有序广播和无序广播(BroadcastReceiver优先级)

    之前我们在Android(java)学习笔记178中自定义的广播是无序广播,下面我们要了解一下有序广播:   1.   我们首先了解一下有序广播和无序广播区别和联系? (1) 有序广播> 接受者 ...

  3. Angular2 - Starter - Component and Component Lifecircle Hooks

    我们通过一个NgModule来启动一个ng app,NgModule通过bootstrap配置来指定应用的入口组件. @NgModule({ bootstrap: [ AppComponent ], ...

  4. C#之垃圾回收

    垃圾回收时现代语言的标志之一.垃圾回收解放了手工管理对象释放的工作,提高了程序的健壮性,但是副作用就是程序代码可以对于创建对象变得随意. 1.避免不必要的对象创建 由于垃圾回收的代价较高,所以C#程序 ...

  5. HTML中的API

    在程序语言里面就使用API这个行为来讲,可拆解为两个操作:取得API接口和运行API功能 例如:书本具有传授知识的功能,这里就好比一个API,学生拿出某个课本学习,就相当于取得API,学习通过课本学习 ...

  6. CodeSmith中SchemaExplorer属性的介绍

    CodeSmith与数据库的联系,在CodeSmith中自带一个程序集SchemaExplorer.dll,这个程序集中的类主要用于获取数据库中各种对象的结构. <%@ Property Nam ...

  7. Sql Xml

    /* sql xml 入门: --by jinjazz --http://blog.csdn.net/jinjazz 1.xml: 能认识元素.属性和值 2.xpath: 寻址语言,类似windows ...

  8. UITableView中容易忽略的知识点

    1.取消余下的分割线 tableView.tableFooterView = UIView() 2.分割线顶格 override func viewDidLayoutSubviews() { self ...

  9. Java8 map和reduce

    map final List<Integer> numbers = Arrays.asList(1, 2, 3, 4); final List<Integer> doubleN ...

  10. 理解MySQL——索引与优化(转)

    写 在前面:索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页 面大小为4K,并存储100条记录.如果没有索引,查 ...