【Mysql实战45讲】06 全局锁、表锁

根据加锁范围,Mysql中的锁可以分为全局锁、表级锁、行锁

1、全局锁

  • 指对整个数据库实例加锁,mysql提供了一个加全局读锁的方法,命令是:flush tables with read lock (FTWRL),执行后整个库会处于只读的状态
  • 使用场景:对全库进行逻辑备份。但它存在风险,比如用这种方式在主库进行备份,那业务功能将暂时不可用;在从库进行备份,备份期间从库不能执行主库同步过来的binlog,从而导致主从延迟。所以比较好的备份方案是在可重复读的隔离级别下开启一个事务,mysql官方自带的备份工具 mysqldump 在使用参数 single-transaction 时,导数据之前会启动一个事务,确保拿到一致性视图,而由于 MVCC 的支持,数据依然可以正常写,但这种方式的前提是引擎支持事务,对于 MyISAM 这种不支持事务的引擎,就需要使用 FTWRL 命令了。

2、表级锁

  • 表锁的语法是:lock tables … read/write。 解锁用 unlock
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值