zl程序教程

您现在的位置是:首页 >  IT要闻

当前栏目

MySQL数据库原理学习(三十七)

2023-02-19 12:23:38 时间

5.2.2 语法

1). 加全局锁

flush tables with read lock ;

2). 数据备份

 mysqldump -uroot –p1234 itcast > itcast.sql

数据备份的相关指令, 在后面MySQL管理章节, 还会详细讲解.

3). 释放锁

unlock tables ;

5.2.3 特点

数据库中加全局锁,是一个比较重的操作,存在以下问题:

如果在主库上备份,那么在备份期间都不能执行更新,业务基本上就得停摆。

如果在从库上备份,那么在备份期间从库不能执行主库同步过来的二进制日志(binlog),会导致主从延迟。

在InnoDB引擎中,我们可以在备份时加上参数 --single-transaction 参数来完成不加锁的一致性数据备份。

mysqldump --single-transaction -uroot –p123456 itcast > itcast.sql

5.3 表级锁

5.3.1 介绍

表级锁,每次操作锁住整张表。锁定粒度大,发生锁冲突的概率最高,并发度最低。应用在MyISAM、InnoDB、BDB等存储引擎中。

对于表级锁,主要分为以下三类:

表锁

元数据锁(meta data lock,MDL)

意向锁

5.3.2 表锁

对于表锁,分为两类:

表共享读锁(read lock)

表独占写锁(write lock)

语法:

加锁:lock tables 表名... read/write。

释放锁:unlock tables / 客户端断开连接 。

特点:

A. 读锁

左侧为客户端一,对指定表加了读锁,不会影响右侧客户端二的读,但是会阻塞右侧客户端的写。

测试:

B. 写锁

左侧为客户端一,对指定表加了写锁,会阻塞右侧客户端的读和写。

测试:

结论: 读锁不会阻塞其他客户端的读,但是会阻塞写。写锁既会阻塞其他客户端的读,又会阻塞
其他客户端的写。