使用MYSQL命令行客户端 执行语句 
FLUSH TABLES WITH READ LOCK
在没有退出客户端的情况下,使用其他客户端连接 发现还是可以进行读写操作。
求解。mysql

解决方案 »

  1.   

    你应该用的是InnoDB吧 innodb_table_locks这个系统变量必须是on才能锁innodb的表
      

  2.   


    实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。
      

  3.   


    实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。请问,您热备的逻辑还是物理?用mysqldump吗?其他客户端新增数据是如何新增?信息能否给详细点
      

  4.   


    实际情况是,我有一个办公系统 然后需要做热备份。所以使用 flush tables with read lock ,锁定表,然后备份数据库。可是在我锁定表之后,发下其他在线的客户端新增数据 还是在进行。请问,您热备的逻辑还是物理?用mysqldump吗?其他客户端新增数据是如何新增?信息能否给详细点
    备份方式是使用拷贝数据库文件的方式备份的,备份工具是使用办公系统服务端PHP完成的。其他客户端指的是在备份的时候,其他正在使用办公系统的用户。他们新增数据的方式就是插入一些办公信息。
      

  5.   

    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>
      

  6.   

    A线程做了FLUSH TABLES WITH READ LOCK操作,B线程做CREATE DATABASE,INSERT操作都被阻塞。Waiting for global read lock