mysql锁
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql锁,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1192字,纯文字阅读大概需要2分钟。
内容图文
根据加锁的范围,MySQL 里面的锁大致可以分成全局锁、表级锁和行锁三类。
全局锁的典型使用场景是,做全库逻辑备份。
MySQL 提供了一个加全局读锁的方法,命令是 Flush tables with read lock (FTWRL)。
官方自带的逻辑备份工具是 mysqldump。当 mysqldump 使用参数–single-transaction 的时候,导数据之前就会启动一个事务,
来确保拿到一致性视图。而由于 MVCC 的支持,这个过程中数据是可以正常更新的。
MyISAM 这种不支持事务的引擎,如果备份过程中有更新,总是只能取到最新的数据,那么就破坏了备份的一致性。这时,我们就需要使用 FTWRL 命令了。
表级锁:
表锁的语法是 lock tables … read/write。
另一类表级的锁是 MDL(metadata lock)。MDL 不需要显式使用,在访问一个表的时候会被自动加上。
给一个小表加个字段,导致整个库挂了。alter table 语句里面设定等待时间。
两阶段锁:两阶段锁协议
如果你的事务中需要锁多个行,要把最可能造成锁冲突、最可能影响并发度的锁尽量往后放。
死锁和死锁检测,出现死锁以后,有两种策略:
一种策略是,直接进入等待,直到超时。这个超时时间可以通过参数innodb_lock_wait_timeout 来设置。
另一种策略是,发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行。将参数 innodb_
deadlock_detect 设置为 on,表示开启这个逻辑。死锁检测要耗费大量的 CPU 资源。会导致由热点行更新导致的性能问题。
内容总结
以上是互联网集市为您收集整理的mysql锁全部内容,希望文章能够帮你解决mysql锁所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。