当前位置: 代码迷 >> 综合 >> MyISAM 表的锁定机制
  详细解决方案

MyISAM 表的锁定机制

热度:93   发布时间:2023-12-06 14:38:31.0

MyISAM 类型表的表级锁定:
1.读锁定不会阻塞其他进程的读。
2.读锁定会阻塞所有线程的写入(insert and update and delete),包括自己所在的进程。
3.如果锁定时加local 参数,则其他线程的inser 不会阻塞,并且在读锁定期间,如其他线程有insert写入数据,此时无法即时看到。但会阻塞update,delete 操作
---------------------------------------------------------------
Lock tables orders read local, order_detail read local;

Select sum(total) from orders;

Select sum(subtotal) from order_detail;

Unlock tables;

上面的例子在LOCK TABLES时加了“local”选项,
其作用就是在满足MyISAM表并发插入条件的情况下,允许其他用户在表尾并发插入记录
---------------------------------------------------------------------
写锁定:
1.写锁定会阻塞其他线程的读;
2.修改表结构不会阻塞其他线程的读锁定。


系统锁定的检查情况:
mysql> show status like 'table%';
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| Table_locks_immediate | 112   |
| Table_locks_waited    | 4     |
+-----------------------+-------+
2 rows in set (0.03 sec)
如果出现table_locks_waited 状态值高,表示有较多的资源争用情况出现。

mysql> show status like 'innodb_row_lock%';
+-------------------------------+-------+
| Variable_name                 | Value |
+-------------------------------+-------+
| Innodb_row_lock_current_waits | 0     |正在等待锁定的数量
| Innodb_row_lock_time          | 0     |锁定总时间长度
| Innodb_row_lock_time_avg      | 0     |平均锁定时间
| Innodb_row_lock_time_max      | 0     |最长锁定时间
| Innodb_row_lock_waits         | 0     |出现等待的总次数
+-------------------------------+-------+
5 rows in set (0.00 sec)

通过创建INNODB monitor 表来打开Innodb 的monitor功能,即时查看Innodb 的实时情况:
create table innodb_monitor(a int) engine=innodb;
然后执行:show innodb status;