• MySQL学习(四)死锁及死锁检测


    文章图片来自参考资料 
    

    MySQL 的锁

        根据加锁的范围,MySQL里面的锁大致可以分成全局锁、表级锁和行锁三类。我们需要明白锁的服务是为了数据统一,或者说是事务,数据隔离。

    全局锁

        全局锁是范围最大的锁,锁住了所有,全局锁的典型使用场景是,做全库逻辑备份。也就是把整库每个表都select出来存成文本。

        总结来自参考资料 使用场景:全库逻辑备份。 风险: 1.如果在主库备份,在备份期间不能更新,业务停摆 2.如果在从库备份,备份期间不能执行主库同步的binlog,导致主从延迟 官方自带的逻辑备份工具mysqldump,当mysqldump使用参数--single-transaction的时候,会启动一个事务,确保拿到一致性视图。而由于MVCC的支持,这个过程中数据是可以正常更新的。

    表级锁

        MySQL里面表级别的锁有两种:一种是表锁,一种是元数据锁(meta data lock,MDL)。     其中表锁就像java 中的 synchronized 方法,直接锁住这个对象,后面来的对象都不能操作,而后者则是像java中的读写锁,读读可以,读写,写读互斥,就像下图。

    1297993-20200115152724236-979207033.jpg

    MDL

        MDL不需要显式使用,在访问一个表的时候会被自动加上。MDL的作用是,保证读写的正确性。你可以想象一下,如果一个查询正在遍历一个表中的数据,而执行期间另一个线程对这个表结构做变更,删了一列,那么查询线程拿到的结果跟表结构对不上,肯定是不行的。

    行锁

    当我们进行进行事务的时候,多个事务对同一行进行操作,就会加行锁,就像下图这个例子。

    1297993-20200115155000154-1686749871.jpg

    所以建议 : 如果你的事务中需要锁多个行,要把最可能造成锁冲突、最可能影响并发度的锁尽量往后放。

    死锁和死锁检测

    1297993-20200115155124624-1033061836.jpg

    死锁--"你等我的钥匙,我等你的钥匙,互不相让"

    死锁处理方案

    当出现死锁以后,有两种策略:

    (1) 一种策略是,直接进入等待,直到超时。这个超时时间可以通过参数innodb_lock_wait_timeout来设置。 (2)发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行。将参数innodb_deadlock_detect设置为on,表示开启这个逻辑。

    参考资料

    • MySQL实战45讲
  • 相关阅读:
    进入用友通:提示"由于文件不可访问,内存磁盘空间不足无法打开ufsystem数据库"...
    HDOJ 1069 Monkey and Banana
    HDOJ 1087 Super Jumping! Jumping! Jumping!
    HDOJ 1209 Clock
    CodeForces Round #185 (Div. 2)A,B,C
    HDOJ 1465 不容易系列之一
    HDOJ 1114 PiggyBank
    HDOJ 1280 前m大的数
    HDOJ 1495 非常可乐
    HDOJ 1284 钱币兑换问题
  • 原文地址:https://www.cnblogs.com/Benjious/p/12197301.html
Copyright © 2020-2023  润新知