• mysql锁


    锁,为什么mysql需要锁?因为存在多用户并发操作同一数据。我们使用的mysql数据包括两种:表本身(字段,索引,类型,大小等),表内数据。表本身的修改DDl操作,表内数据增删改查,因此也都需要锁。
    锁按数据操作方式分有两种:读锁,写锁。分别对应查,增删改。按照锁范围分:全局锁,表锁,行锁,元数据锁(锁表结构的修改)。
    锁解决了并发问题,但同时锁的引入也必然会带来其它问题。没有无缘无故没有代价的好处。随着锁的引入,性能方面会有所损失。这里就涉及锁的释放时,我们知道mysql的InoDB执行引擎是支持事务的。
    在这里插入图片描述
    由于id=1的数据被事务A锁定,所以事务A提交后,事务B才执行。行锁是在执行update语句时加上的,从以上结论分析,可得出行锁是在事务A提交之后释放的。这就是两阶段锁。如果一个事务中有多条语句,是不是很影响性能。为了减少所等待,优化的方式就是让影响比较大的语句往后防,晚些加锁。
    第二个影响死锁和死锁检测
    在这里插入图片描述
    死锁的两种解决方案:、
    1.设置innodb_deadlock_detect =on表示开启,通过innodb_lock_wait_timeout设置解锁时间。默认50s
    这种方式明显不好,设置时间长业务等待时间长,设置时间短,也许正常业务因网络延迟被误判。
    2.主动死锁检测
    死锁检测是发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行。将参数 innodb_deadlock_detect 设置为 on,表示开启这个逻辑。
    一个事务开启后,加锁之后会检查它需要的锁是不是已经被其他事务持有,
    死锁检测会占用大量的cpu。

  • 相关阅读:
    线程池的核心原理篇
    RustDay01——运行在线GitHub Rust环境
    高等数学(第七版)同济大学 习题2-1 个人解答
    mysql大表ddl注意
    Unity C#随笔:简述String和StringBuilder的区别
    算法竞赛备赛进阶之状态机模型训练
    WPF 控件专题 ScrollBar控件详解
    v-show与v-if控制图片显隐的本质
    go gtk3 pcman-key
    Centos7.x修改网卡名称
  • 原文地址:https://blog.csdn.net/weixin_41492331/article/details/127772505