FLUSH TABLES WITH READ LOCK 无效

T121581 2013-10-19 04:13:21
使用MYSQL命令行客户端 执行语句
FLUSH TABLES WITH READ LOCK
在没有退出客户端的情况下,使用其他客户端连接 发现还是可以进行读写操作。
求解。
...全文
398 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
珠海-天堂 2013-10-24
  • 打赏
  • 举报
回复
A线程做了FLUSH TABLES WITH READ LOCK操作,B线程做CREATE DATABASE,INSERT操作都被阻塞。 Waiting for global read lock
珠海-天堂 2013-10-24
  • 打赏
  • 举报
回复
mysql> FLUSH TABLES WITH READ LOCK;
Query OK, 0 rows affected (0.01 sec)

mysql> show processlist;
+----+------+-----------------+------+---------+------+-------------------------
-----+----------------------+
| Id | User | Host            | db   | Command | Time | State
     | Info                 |
+----+------+-----------------+------+---------+------+-------------------------
-----+----------------------+
|  1 | root | localhost:50424 | NULL | Query   |    0 | NULL
     | show processlist     |
|  2 | root | localhost:50427 | NULL | Query   |    6 | Waiting for global read
lock | create database dbdd |
+----+------+-----------------+------+---------+------+-------------------------
-----+----------------------+
2 rows in set (0.00 sec)

mysql> show processlist;
+----+------+-----------------+------+---------+------+-------+-----------------
-+
| Id | User | Host            | db   | Command | Time | State | Info
 |
+----+------+-----------------+------+---------+------+-------+-----------------
-+
|  1 | root | localhost:50424 | NULL | Query   |    0 | NULL  | show processlist
 |
|  2 | root | localhost:50427 | NULL | Sleep   |   20 |       | NULL
 |
+----+------+-----------------+------+---------+------+-------+-----------------
-+
2 rows in set (0.00 sec)

mysql> show processlist;
+----+------+-----------------+------+---------+------+-------------------------
-----+------------------------------+
| Id | User | Host            | db   | Command | Time | State
     | Info                         |
+----+------+-----------------+------+---------+------+-------------------------
-----+------------------------------+
|  1 | root | localhost:50424 | NULL | Query   |    0 | NULL
     | show processlist             |
|  2 | root | localhost:50427 | test | Query   |    3 | Waiting for global read
lock | insert into tage values(1,2) |
+----+------+-----------------+------+---------+------+-------------------------
-----+------------------------------+
2 rows in set (0.00 sec)

mysql>







T121581 2013-10-21
  • 打赏
  • 举报
回复
引用 6 楼 linwaterbin 的回复:
[quote=引用 5 楼 T121581 的回复:] [quote=引用 4 楼 linwaterbin 的回复:] 全局读锁,写服务会被停止,但读请求还是正常的,
实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。[/quote] 请问,您热备的逻辑还是物理?用mysqldump吗?其他客户端新增数据是如何新增?信息能否给详细点[/quote] 备份方式是使用拷贝数据库文件的方式备份的,备份工具是使用办公系统服务端PHP完成的。其他客户端指的是在备份的时候,其他正在使用办公系统的用户。他们新增数据的方式就是插入一些办公信息。
linwaterbin 2013-10-20
  • 打赏
  • 举报
回复
引用 5 楼 T121581 的回复:
[quote=引用 4 楼 linwaterbin 的回复:] 全局读锁,写服务会被停止,但读请求还是正常的,
实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。[/quote] 请问,您热备的逻辑还是物理?用mysqldump吗?其他客户端新增数据是如何新增?信息能否给详细点
T121581 2013-10-20
  • 打赏
  • 举报
回复
引用 4 楼 linwaterbin 的回复:
全局读锁,写服务会被停止,但读请求还是正常的,
实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。
linwaterbin 2013-10-19
  • 打赏
  • 举报
回复
全局读锁,写服务会被停止,但读请求还是正常的,
rucypli 2013-10-19
  • 打赏
  • 举报
回复
贴你的执行sql
ACMAIN_CHM 2013-10-19
  • 打赏
  • 举报
回复
其实连接读操作应该可以,但写操作应该不行啊。
liuxinran819 2013-10-19
  • 打赏
  • 举报
回复
你应该用的是InnoDB吧 innodb_table_locks这个系统变量必须是on才能锁innodb的表

56,679

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧