MyISAM 表的锁定机制

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值