Welcome 微信登录

首页 / 数据库 / MySQL / MySQL源代码:如何对读写锁进行处理

最近碰到一个问题,线上一台机器在等待信号量时间过长,mysql的监控线程认为此时mysqld已经hang住了,于是自杀重启。这里涉及到一个有趣的问题,也就是mysql如何对读写锁进行处理。主要包括三个部分:1. 建锁2. 加锁3. 解锁4. 监控锁 以下内容基于Percona5.5.18进行分析 1.创建锁锁的创建实际上就是初始化一个RW结构体(rw_lock_t),实际调用函数如下:[cpp]
  1. # define rw_lock_create(K, L, level)                                    
  2.          rw_lock_create_func((L),#L)  
在rw_lock_create上有三个参数,在实际场景锁时只用到第2个参数其中K表示mysql_pfs_key_t,level显示当前的操作类型(起码看起来是的,在文件sync0sync.h中定义),看起来k是为performance schema准备的,而k代表了当前操作所在的层次。例如:purge线程的读写锁创建:[html]
  1. rw_lock_create(trx_purge_latch_key,  
  2.                  &purge_sys->latch,SYNC_PURGE_LATCH);  
我们进去rw_lock_create_func看看到底是怎么创建的。 可以看到这个函数的逻辑其实很简单:lock->lock_word =X_LOCK_DECR;    //关键字段用于限制读写锁的最大并发数,代码里的注释如下:[cpp]
  1. /* We decrement lock_word by this amountfor each x_lock. It is also the 
  2. start value for the lock_word, meaning thatit limits the maximum number 
  3. of concurrent read locks before the rw_lockbreaks. The current value of 
  4. 0x00100000 allows 1,048,575 concurrentreaders and 2047 recursive writers.*/  
在尝试加锁时会调用rw_lock_lock_word_decr减少lock_word  在初始化一系列变量后,执行:[cpp]
  1. lock->event = os_event_create(NULL);  
  2. lock->wait_ex_event = os_event_create(NULL);  
os_event_create用于创建一个系统信号,实际上最终创建的还是互斥量(os_fast_mutex_init(&(event->os_mutex));以及条件变量(os_cond_init(&(event->cond_var));) 最后将lock加入到全局链表rw_lock_list中 
  • 1
  • 2
  • 3
  • 4
  • 下一页
MySQL源代码:如何对读写锁进行处理MySQL源代码:如何对读写锁进行处理相关资讯      MySQL基础教程 
  • MySQL基础教程:关于varchar(N)  (01月22日)
  • MySQL SELECT同时UPDATE同一张表  (02/19/2013 07:20:18)
  • Linux修改MySQL最大并发连接数  (02/15/2013 15:37:21)
  • 高性能MySQL(第3版) 中文PDF带目  (10/26/2014 10:03:50)
  • 如何在MySQL中的获取IP地址的网段  (02/18/2013 12:23:33)
  • C++和C#访问MySQL的简单代码示例  (12/21/2012 09:04:10)
本文评论 查看全部评论 (0)
表情: 姓名: 字数