MySQL锁机制概述及表锁分析

MySQL锁机制

定义:

锁是计算机协调多个进程或线程并发访问某一资源的机制。

在数据库中中,除传统的计算资源(如CPU、RAM、I/O等) 的争用以外,数据也是一种供多个用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的问题,锁冲突也是影响数据库并发访问性能的一个重要因素。因此,锁对于数据库也是很重要的。

锁的分类

从数据操作的类型可分为读锁、写锁

读锁(共享锁):针对同一份数据,多个读操作可以同时进行而不会互相影响

写锁(排他锁):当前写操作没有完成前,它会组大运其他写锁和读锁。

从对数据操作的颗粒度上可分为表锁、行锁。

表锁

特点:偏向MyISAM存储引擎,开销小,加锁快,无死锁,锁定粒度大,发生锁冲突的概率最高,并发最低。

以dept表为例演示表锁

手动添加表锁

lock table 表名称 read(write),表名称2 read(write)…

查看表上加过的锁

show open tables;

释放表锁

unlock tables;

为dept表加读锁

lock table dept read;

在这里插入图片描述
在这里插入图片描述

为dept加写锁

lock table dept write;

在这里插入图片描述

在这里插入图片描述

可见加了写锁后,其他会话连读都不能了,更别说其他会话的写操作了。

结论:读读共享,读写互斥,写写互斥

表锁分析

查看哪些表被加锁了

show open tables;

如何分析表锁定

可以通过检查table_locks_waitedtable_locks_immediate状态变量来分析系统上的表锁定。

show status like 'table%';

table_locks_waited表示出现表级锁定争用而发生等待的次数(不能立即获取锁的次数,每等待一次锁值加1)。此值高说明存在严重的表级锁争用情况

table_locks_immediate表示产生表级锁定的次数,表示可以立即获取锁的查询次数,每立即获取锁值加1。

mysql> show status like 'table%';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| Table_locks_immediate      | 105   |
| Table_locks_waited         | 0     |
| Table_open_cache_hits      | 41    |
| Table_open_cache_misses    | 4     |
| Table_open_cache_overflows | 0     |
+----------------------------+-------+

因为MyISAM支持表锁,而MyISAM的读写锁调度是写优先,这也是MyISAM不适合做写为主的引擎的原因。因为写锁后,其他线程不能做任何操作,大量的更新会使查询很难得到锁,从而造成长时间的阻塞。

发布了116 篇原创文章 · 获赞 23 · 访问量 8万+

猜你喜欢

转载自blog.csdn.net/zyxwvuuvwxyz/article/details/104596921