mysql实战45讲笔记--07

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

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

死锁和死锁检测

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

你可能感兴趣的:(学习笔记)