mysql中的全局锁是什么

发布时间:2021-09-08 10:22:47 作者:chen
来源:亿速云 阅读:161

这篇文章主要讲解了“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中的全局锁是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. MySQL中的锁是什么?
  2. MySQL中怎么实现全局锁和表锁

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql

上一篇:mysql启动事务的方法有哪些

下一篇:css中怎么实现背景定位

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》