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