http://www.cnblogs.com/xpchild/p/3782311.html

 

MySQL的锁:
MySQL内部有很多种类的锁,按照用途不同,可以分为两类:
1. 保护内存结构的锁,实现同步机制
  server层对于线程共享的变量,基本上使用mutex,rwlock来做保护。
  innodb层会增加使用spinlock自旋锁

2. 提供或者保证事务性功能的锁
  server提供了MDL锁,表锁两种锁
  innodb实现行级锁

原子操作:

  在单处理器系统(UniProcessor)结构中,在一个指令周期内完成的都是原子指令,因为硬中断的响应是在每一个cpu指令完成后check的。
而在多处理器结构(Symmetric Multi-Processor)中,要想完成一个原子指令,还需要保证多个core之间的一致性,这里就引入了锁总线的步骤。

例如:x86体系下的cmpxchg指令

下面使用原子指令来实现mutex,rwlock,spinlock的简单伪代码

1. mutex的伪代码:

mutex_lock:
1
2
3
4
5
6
while(1)
  if cmpxchg(*lock,0,1)==0
    success
    break;
  else
    futex(wait)

mutex_unlock:

1
2
3
if cmpxchg(*lock,1,0)==0
  futex(wakeup)
  success

  

2. spinlock的伪代码:

spinlock_lock:

1
2
3
4
5
while(1)
  /* spin */
  if compchg(*lock,0,1)==0
    success
    break

spinlock_unlock:

1
2
if cmpxchg(*lock,1,0)==0
success

  

3. rwlock的伪代码:

/* variables */

1
2
3
4
mutex_lock rw_mutex
int r_cnt;
int w_cnt;
int if_has_w_req;/* 防饿死*/

rwlock_r_lock:

1
2
3
4
5
6
7
8
9
<em>mutex_lock(rw_mutex)
while(1)
  if(!if_has_w_req && w_cnt ==0)
    success
    r_cnt++
    mutex_unlock(rw_mutex)
    return
  else
    futex(wait)</em>

rwlock_r_unlock:

1
2
3
4
mutex_lock(rw_mutex)
r_cnt--;
mutext_unlock(rw_mutex)
fetex(wake_up)

rwlock_w_lock:

1
2
3
4
5
6
7
8
9
10
11
mutex_lock(rw_mutex)
if_has_w_req++
while(1)
  if(r_cnt>0 ||w_cnt >0)
    fetux(wait)
  else
    if_has_w_req--
    success
    w_cnt++;
    break
mutext_unlock(rw_mutex)

rwlock_w_unlock:

1
2
3
mutex_lock(rw_mutex)
w_cnt--
mutex_unlock(rw_mutex)

  

下面通过几篇blog分别介绍一下MySQL事务中的表锁,mdl元数据锁,innodb锁:

另外:关于死锁的讨论,这里先列出需要关注的两点:

1. 内存结构的锁,必须控制加锁的顺序,保证逻辑上不出现死锁
2. 事务锁,在无法保证用户的使用数据库行为的时候,需要死锁检测

附tips:

  在mutex的使用上的一个小tips:

  因为thread如果已经获得了mutex, 那么如果再次lock的话,会产生死锁,要么代码能够控制好,要么可以使用下面的这个结构:

typedef struct my_mutex{
  pthread_mutext_t mutex;
   pthread_t thread;
   unsigned count;
}my_mutex;

在lock之前,使用 mutex_is_owner()来判断是否已经拿到这个mutex了。

bool mutex_is_owner( my_mutex * mutex){
  return pthread_equal(thread_self(), mutex->thread);
}

MySQL锁系列1的更多相关文章

  1. MySQL锁系列3 MDL锁

    http://www.cnblogs.com/xpchild/p/3790139.html   MySQL为了保护数据字典元数据,使用了metadata lock,即MDL锁,保证在并发的情况下,结构 ...

  2. MySQL锁系列2 表锁

    http://www.cnblogs.com/xpchild/p/3789068.html   上一篇介绍了MySQL源码中保护内存结构或变量的锁,这里开始介绍下MySQL事务中的表锁. 注1: 在表 ...

  3. MySQL锁系列之锁的种类和概念

    转自:http://keithlan.github.io/2017/06/05/innodb_locks_1/ 锁是MySQL里面最难理解的知识,但是又无处不在. 一开始接触锁的时候,感觉被各种锁类型 ...

  4. Mysql高手系列 - 第26篇:聊聊如何使用mysql实现分布式锁

    Mysql系列的目标是:通过这个系列从入门到全面掌握一个高级开发所需要的全部技能. 欢迎大家加我微信itsoku一起交流java.算法.数据库相关技术. 这是Mysql系列第26篇. 本篇我们使用my ...

  5. Mysql优化系列(2)--通用化操作梳理

    前面有两篇文章详细介绍了mysql优化举措:Mysql优化系列(0)--总结性梳理Mysql优化系列(1)--Innodb引擎下mysql自身配置优化 下面分类罗列下Mysql性能优化的一些技巧,熟练 ...

  6. Mysql备份系列(4)--lvm-snapshot备份mysql数据(全量+增量)操作记录

    Mysql最常用的三种备份工具分别是mysqldump.Xtrabackup(innobackupex工具).lvm-snapshot快照.前面分别介绍了:Mysql备份系列(1)--备份方案总结性梳 ...

  7. Mysql备份系列(1)--备份方案总结性梳理

    mysql数据库备份有多么重要已不需过多赘述了,废话不多说!以下总结了mysql数据库的几种备份方案: 一.binlog二进制日志通常作为备份的重要资源,所以再说备份方案之前先总结一下binlog日志 ...

  8. Mysql锁机制--并发事务带来的更新丢失问题

    Mysql 系列文章主页 =============== 刚开始学习 Mysql 锁的时候,觉得 Mysql 使用的是行锁,再加上其默认的可重复读的隔离级别,那就应该能够自动解决并发事务更新的问题.可 ...

  9. Mysql锁机制--索引失效导致行锁变表锁

    Mysql 系列文章主页 =============== Tips:在阅读本文前,最好先阅读 这篇(Mysql锁机制--行锁)文章~ 在上篇文章中,我们看到InnoDB默认的行锁可以使得操作不同行时不 ...

随机推荐

  1. 浅析基层检察院派驻乡镇检察室的健康发展 z

    时间:2011-03-22 10:08 作者:祝志方 新闻来源:正义网 一.前言 在我国,基层检察院派驻乡镇检察室的发展经过了一个曲折发展的历程,上世纪80年代,随着经济社会的发展,一批乡镇检察室应运 ...

  2. bjfu1100 圆环

    这题也是2011百度之星的一道题.知道做法后代码极简单. 不过我做完后随便上网搜了一下,发现竟然还有很多不同的做法.别的做法我就不管了,我只把我的做法的原理说清楚.我做题时是按如下顺序逐步找到规律的: ...

  3. 【剑指offer 面试题21】包含min函数的栈

    思路: 通过增加一个辅助栈保存每个状态对应的最小值.栈实现的不完整,应该还包含empty()等常规函数. #include <iostream> #include <stack> ...

  4. java ant 命令大全

    ANT命令总结 1 Ant是什么? Apache Ant 是一个基于 Java的生成工具.生成工具在软件开发中用来将源代码和其他输入文件转换为可执行文件的形式(也有可能转换为可安装的产品映像形式).随 ...

  5. [算法] 快速排序 Quick Sort

    快速排序(Quick Sort)使用分治法策略. 它的基本思想是:选择一个基准数,通过一趟排序将要排序的数据分割成独立的两部分:其中一部分的所有数据都比另外一部分的所有数据都要小.然后,再按此方法对这 ...

  6. HDU 4882 ZCC Loves Codefires (贪心)

    ZCC Loves Codefires 题目链接: http://acm.hust.edu.cn/vjudge/contest/121349#problem/B Description Though ...

  7. JSF 2 multiple select dropdown box example

    In JSF, <h:selectManyMenu /> tag is used to render a multiple select dropdown box – HTML selec ...

  8. UIImage 相关操作

    修改UIImage大小 修改UISlider的最大值和最小值图片的时候,发现需要修改图片的大小,否则会导致UISlider变形.目前苹果还不支持直接修改UIImage类的大小,只能修改UIImageV ...

  9. Web安全--使用Salt + Hash将密码加密后再存储进数据库

    转载原地址 http://www.bozhiyue.com/mianshiti/_net/2016/0728/314239.html (一) 为什么要用哈希函数来加密密码 如果你需要保存密码(比如网站 ...

  10. HDU 3966 Aragorn's Story (树链点权剖分,成段修改单点查询)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3966 树链剖分的模版,成段更新单点查询.熟悉线段树的成段更新的话就小case啦. //树链剖分 边权修 ...