mysql实战45讲笔记--07

07 行锁功过:怎么减少行锁对性能的影响

        Mysql的行锁是在引擎层由各个引擎自己实现的,不是所有数据库都支持行锁比如MyISAM
        行锁就是针对数据表中行记录的锁。
        在InnoDB事务中,行锁是在需要的时候才加上的,但并不是不需要了就立刻回访,而是等到事务结束时才释放,这就是两阶段锁协议。
        因此,如果事务中需要锁多个行 ,要把最可能造成锁冲突,最可能影响并发度的锁尽量往后放。
        一致性读不会加锁,就不需要做死锁检测;

死锁和死锁检测

        并发系统中不同线程出现循环资源依赖,都在等别人释放资源
        当出现了死锁之后,有两种策略
        1.直接进入等待,直到超时,这个超时时间通过参数innodb_lock_wait_timeout设置
        2.发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务继续执行,将参数unnodb_deadlock_detect设置为on,表示开启这个逻辑.
        一般采用第二种策略,因为第一种不好控制时间设置,但是第二种需要耗量大量cpu资源
        因此死锁检测的思路,1.确保业务中不会出现死锁,可以临时把死锁检测关闭2.控制并发度

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
限时福利1:购课进答疑群专享柳峰(刘运强)老师答疑服务 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精精练,帮助程序员吊打面试官,获得心仪的工作机会。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值