写在前面

这是我读别人博客的文章也是mysql高性能一书的关于锁的章节,读的时候有很多概念理解起来确实有点难,所以我在这里再总结一下,关于一些概念或例子我直接就转载别人的内容,自己再写下感悟。有些概念不只是读一遍就全能理解透了,需要你自己亲自试验!另外,我发现有时候别人跟你说一些比较深的技术的时候会觉得他很牛,其实自己去研究一番发现也就是那回事。而且别人说的也不是完全对。

内容开始:锁的基本概念

锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(如CPU、RAM、I/O等)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。本章我们着重讨论MySQL锁机制的特点,常见的锁问题,以及解决MySQL锁问题的一些方法或建议。
MySQL锁概述
相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。
MySQL这3种锁的特性可大致归纳如下。
开销、加锁速度、死锁、粒度、并发性能
l 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
l 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
l 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。
从上述特点可见,很难笼统地说哪种锁更好,只能就具体应用的特点来说哪种锁更合适!仅从锁的角度来说:表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用;而行级锁则更适合于有大量按索引条件并发更新少量不同数据,同时又有并发查询的应用,如一些在线事务处理(OLTP)系统。这一点在本书的“开发篇”介绍表类型的选择时,也曾提到过。下面几节我们重点介绍MySQL表锁和 InnoDB行锁的问题,由于BDB已经被InnoDB取代,即将成为历史,在此就不做进一步的讨论了。

感悟

通常我们理解inndb和myisam引擎的概念,认为inndb适合高并发和R/W比例较小的也就是写为主的表,myisam适合R/W比例教大读为主的表。为什么呢?其实就是因为他们的锁机制导致。具体的我们后面再介绍

更多相关文章

  1. mysql中insert...select引发的死锁
  2. delphi+sql server 数据库死锁问题。高分求解!!!!!
  3. java死锁的例子

随机推荐

  1. Mono For Android 中重要的命名空间
  2. Android中创建对话框(确定取消对话框、单
  3. 横竖屏切换时候activity的生命周期 andro
  4. android 处理运行时改变 开发文档翻译
  5. Android(安卓)应用开发的耗电量控制
  6. 疯狂Android讲义(第2版)
  7. android/c++ opencv 攻坚篇(一) ndk运行
  8. android ART-逆向研究者的福音?
  9. 我所理解的Android模块化(四)——常见问题
  10. Android开发之--脚本编程