msyql 线程互斥锁

在线程服务器中,几个线程可能会访问全局共享数据,所以每个线程必须保证访问时互斥的,通过互斥锁可以实现这一目的。

这里有几个解决方案

1  使用多个互斥体,一个互斥体保护一段全局数据。优点是可以提高并发性;缺点是当需要访问一组数据时,你必须为每一段数据获得一个互斥体,这样的话容易产生死锁,除非你能控制访问各个资源的顺序一致性。

2  为所有变量使用一个互斥锁。优点是访问时不易产生死锁。缺点是必须加锁,解锁,这样的话就会有大量的线程阻塞,导致并发下降。


mysql 选择的是一个折中的方案,对全局变量进行某种平衡分组,以及为每个分组使用一个互斥体。平衡分组算法很重要! 这样并发受到的影响较小,同时如果算法得当,那么在分组理想的情况下,比如某线程需要访问三段全局数据,分组就将他们放在一个组内,这样不会产生死锁,当然还是得加锁,解锁,同时死锁还是不可避免的,但是风险明显减小了。至于全局互斥体列表及他们保护的组变量,可以参考源码。比如LOCK_error_log互斥体保护的就是错误日志写入等。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值