这篇文章主要讲解了“mysql中的全局锁是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中的全局锁是什么”吧!
1、全局锁就是对整个数据库实例加锁。
2、MySQL提供了一个加全局读锁的方法,命令是Flush tables with read lock。当整个数据库需要只读时,可以使用这个命令。
然后其他线程的以下句子会被堵塞:数据更新句子(数据增删)、数据定义句子(包括建表、修改表结构等。)和更新事务的提交句子。
典型的全局锁使用场景是做全库逻辑备份。也就是说,整个库的每个表都被select存储成文本。
但让整个库只读,可能会出现以下问题:
如果在主库备份,备份期间不能更新,业务基本停止。
若从库备份,则在备份期间无法执行主库同步的binlog,则会导致主从延迟。
打开可重复读隔离级别的事务可以获得一致性视图。
mysqldump是官方的逻辑备份工具。当mysqldump使用参数-single-transaction时,将在导数据之前启动事务,以确保获得一致性视图。由于MVCC的支持,数据可以在这个过程中正常更新。single-transaction仅适用于所有表使用事务引擎的库。
既然要全库只读,为什么不用setglobalreadonly=true?
在一些系统中,readonly的值将被用作其他逻辑,例如,它用于判断一个库是主库还是备库。因此,修改global变量的方法有更大的影响。
异常处理机制存在差异。如果在执行Flushtableswithreadlock命令后,由于客户端异常断开,MySQL会自动释放整个锁,整个库会回到正常更新的状态。在将整个库设置为readonly,如果客户端出现异常,数据库将始终保持readonly状态,这将导致整个库长期处于不可写状态,风险更高。
感谢各位的阅读,以上就是“mysql中的全局锁是什么”的内容了,经过本文的学习后,相信大家对mysql中的全局锁是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。