MySQL源代码:如何对读写锁进行处理
最近碰到一个问题,线上一台机器在等待信号量时间过长,mysql的监控线程认为此时mysqld已经hang住了,于是自杀重启。这里涉及到一个有趣的问题,也就是mysql如何对读写锁进行处理。
主要包括三个部分:
1. 建锁
2. 加锁
3. 解锁
4. 监控锁
以下内容基于Percona5.5.18进行分析
1.创建锁
锁的创建实际上就是初始化一个RW结构体(rw_lock_t),实际调用函数如下:
- # define rw_lock_create(K, L, level) \
- rw_lock_create_func((L),#L)
在rw_lock_create上有三个参数,在实际场景锁时只用到第2个参数
其中K表示mysql_pfs_key_t,level显示当前的操作类型(起码看起来是的,在文件sync0sync.h中定义),看起来k是为performance schema准备的,而k代表了当前操作所在的层次。
例如:purge线程的读写锁创建:
- rw_lock_create(trx_purge_latch_key,
- &purge_sys->latch,SYNC_PURGE_LATCH);
可以看到这个函数的逻辑其实很简单:
lock->lock_word =X_LOCK_DECR; //关键字段
用于限制读写锁的最大并发数,代码里的注释如下:
- /* We decrement lock_word by this amountfor each x_lock. It is also the
- start value for the lock_word, meaning thatit limits the maximum number
- of concurrent read locks before the rw_lockbreaks. The current value of
- 0x00100000 allows 1,048,575 concurrentreaders and 2047 recursive writers.*/
在初始化一系列变量后,执行:
- lock->event = os_event_create(NULL);
- lock->wait_ex_event = os_event_create(NULL);
最后将lock加入到全局链表rw_lock_list中
相关推荐
IT之家 2020-03-11
graseed 2020-10-28
zbkyumlei 2020-10-12
SXIAOYI 2020-09-16
jinhao 2020-09-07
impress 2020-08-26
liuqipao 2020-07-07
淡风wisdon大大 2020-06-06
yoohsummer 2020-06-01
chenjia00 2020-05-29
baike 2020-05-19
扭来不叫牛奶 2020-05-08
hxmilyy 2020-05-11
黎豆子 2020-05-07
xiongweiwei00 2020-04-29
Cypress 2020-04-25
冰蝶 2020-04-20