全局锁和表锁

栏目: 数据库 · 发布时间: 6年前

内容简介:全局锁两种方式:以上两种方式不同点:使用
  • 对整个数据库实例加锁
  • 使用场景:做全库逻辑备份时,为了保证备份期间的库在同一个逻辑时间点,即一致性视图(类似于可重复读隔离级别的效果)

全局锁两种方式:

  • Flush tables with read lock(FTWRL) 使数据库处于只读状态,数据的增删改、数据定义语句和更新类事务的提交语句都会被阻塞
  • mysqldump 官方自带的逻辑备份工具,参数 -single-transaction 会在导数据之前启动一个事务,确保拿到一致性视图

以上两种方式不同点:

使用 mysqldump 前提是 引擎支持隔离级别 ,所以 single-transaction 方法只适用于支持事务引擎的库;MyISAM不支持事务,所以只能使用FTWRL命令

set global readonly = true 
复制代码

这条语句也可以做到全库只读,但是不建议使用:

  • 有时readonly会用来判断库是主库还是备库,因此修改global变量的方式影响会比较大
  • 异常处理方面:FTWRL后客户端异常断开,MySQL会自动释放全局锁,库恢复正常;设置readonly,客户端异常,则会保持readonly,会导致长时间处于不可写状态,风险较高

以上哪种方式,一个库被全局上锁后,对立面任何一个表做字段操作,都会被锁住的

即使没有全局加锁,有了表级锁,加字段也会遇到问题

表级锁

MySQL有两种表级别的锁:一种是表锁、另一种是元数据锁(metadata lock,MDL)

表级锁的语法: lock tables xxx read/write

例如 线程A执行了 lock table t1 read,t2 write 效果是 包括A线程在内的所有线程对于t1表只可读,写被阻塞;t2表读写都被阻塞

lock tables操作可以用unlock tables主动释放,也可以在客户端断开的时候自动释放。

该操作不仅阻塞其他线程的操作,也阻塞了当前线程的操作

对于innoDB这种支持行锁的引擎,一般不使用 lock tables 命令控制并发,影响过大

另一种表级锁: MDL(metadata lock)

MDL在访问一个表的时候会自动加上,MDL的作用是,保证读写的正确性。当表做增删改查操作时,加MDL读锁;当对表结构变更的时候,加MDL写锁。

  • 读锁之间不互斥,多线程可对同一张表增删改查
  • 读写锁之间、写锁之间互斥。两个线程同时给一个表增加字段,则第二个需要等待第一个执行完才能继续
  • MDL锁在语句执行开始时申请,事务结束后释放

如何给小锁安全的加字段

  • 解决长事务,当做DDL变更的表中正好在执行长事务,则从information_schema库的innodb_trx找到当前执行长事务,先kill掉长事务或者暂停DDL
  • 比较理想的状态:修改表结构语句alter table可以设置等待时间,如果该时间内拿不到MDL锁,则该时间内拿不到MDL锁,则放弃执行,不会阻塞后面的语句
    MariaDB/ALiSQL已经支持 DDL NOWAIT/WAIT n 这个语法
alter table tb1_name NOWAIT add column...
alter table tb1_name WAIT N add column...   
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

About Face 3

About Face 3

Alan Cooper、Robert Reimann、David Cronin / John Wiley & Sons / 2007-5-15 / GBP 28.99

* The return of the authoritative bestseller includes all new content relevant to the popularization of how About Face maintains its relevance to new Web technologies such as AJAX and mobile platforms......一起来看看 《About Face 3》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具