千家信息网

mysql的锁机制

发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,锁概述mysql锁机制的特点: 不同存储引擎支持不同的锁机制。MyISAM和MEMORY存储引擎支持表级锁;BDB存储引擎采用页面锁;InnoDB存储引擎支持行级锁。表级锁:开销小,加锁快,不会出现死
千家信息网最后更新 2024年11月11日mysql的锁机制

锁概述

mysql锁机制的特点: 不同存储引擎支持不同的锁机制。

MyISAM和MEMORY存储引擎支持表级锁;
BDB存储引擎采用页面锁;
InnoDB存储引擎支持行级锁。
  • 表级锁:

    开销小,加锁快,不会出现死锁,锁定粒度大,加锁冲突概率最高,并发度最低;
    适用于以查询为主,只有少量按索引条件更新数据的应用,如Web应用;
  • 行级锁

    开销大,加锁慢,会出现死锁,锁定粒度小,发生锁冲突的概率最低,并发度最高;
    适合于有大量按索引条件并发更新少量不同数据,同时又有并发查询的应用,如一些在线事务处理(OLTP)系统。
  • 页面锁

    开销和加锁时间介于表锁和行锁之间,会出现死锁,锁定粒度介于表锁和行锁之间,并发度一般;

MyISAM表锁

查询表级锁的争用情况

mysql> show status like 'table%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| Table_locks_immediate | 19 |
| Table_locks_waited | 0 |
+-----------------------+-------+
2 rows in set (0.00 sec)

table_locks_waited的值越大,表级锁的争用情况越严重

表级锁的锁模式

  • 表共享读锁
  • 表共享写锁

MyISAM表读操作,不会阻塞其他用户对同一表的读请求,但会阻塞对同一表的写请求;
MyISAM表的写操作,会阻塞其他用户对同一表的读请求和写请求。
MyISAM表的读操作和写操作之间,以及写操作之间是串行的

如何加表锁

MyISAM表在执行SELECT语句之前,会自动给涉及到的表加读锁,在执行UPDATE、DELETE、INSERT之前,自动给涉及到的表加写锁。

当然也可以显示手动加锁,用来模拟事务操作。

mysql> lock table tbl_name1 read/write;
mysql> lock tables tbl_name1 read [local], tbl_name2 write [local];

mysql> unlock tables;

注意:对表加锁之后,使用该表的别名也是不允许的,需要对别名也进行锁定,如下:

mysql> lock table tbl_name1 as tb1 read;
mysql> select a.id from tbl_name tb1;

MyISAM的并发插入

MyISAM的读写操作是串行的,但一定程度上,也是支持查询和插入的并发进行,但不可以删除和更新。

在MyISAM引擎中有一个系统变量 concurrent_insert ,专门用来控制并发插入的行为,有三种取值:

0-> 不允许并发插入;
1-> 在MyISAM表没有孔洞的前提下,允许在读的同时,另一个进程从尾部插入记录(默认)
2-> 不论有无空洞,都可以在表尾并发插入

整理空间碎片:

mysql> optimize table tbl_name;

MyISAM的锁调度

已经知道,MyISAM存储引擎的读锁和写锁是互斥的,读写操作是串行的,但是,及时读请求先到达等待队列,写请求后到达等待队列,写锁也会插入到读锁之前,因为MySQL认为写操作比读操作重要。

同时,这也是MyISAM表不适合有大量更新和查询操作的原因,因为大量的更新和查询操作会占据锁等待队列,读锁会被长时间等待。

为了解决这个问题,我们有一些参数设置来调节MyISAM的调度行为。

  • 启动low-priority-updates,使得MyISAM 默认基于读请求以优先的权利;

  • 降低更新请求的的优先级

mysql> set LOW_PRIORITY_UPDATES=1

  • 指定INSERT、UPDATE、DELETE语句的LOW_PRIORITY属性,降低该语句的优先级

  • 一种折中的方案:给系统参数max_write_locl_count设置一个合适的值,当表的读操作达到该值之后,MySQL就暂时将写请求的优先级降低。

InnoDB锁

InnoDB与MyISAM的最大不同支出在于:1、支持事务;2、采用了行级锁。

查询InnoDB行锁的争用情况

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_row_lock_waits和Innodb_row_lock_time_avg的值越大,表级锁的争用情况越严重

InnoDB行锁模式

  • 共享锁(S)

    允许一个事务去读一行,阻止其他事务获得相同数据集的排他锁

  • 排他锁(X)

    允许获得排他锁的事务更新数据,阻止其他事务取得相同数据集的共享读锁和排他写锁

为了行锁表锁共存,实现多粒度锁机制,InnoDB还有两种内部使用的意向锁,这两种意向锁都是表锁
  • 意向共享锁(IS)

    事务在给一个数据行加共享锁之前,必须先取得该表的IS锁

  • 意向排他锁(IX)

    事务在给一个数据行加排他锁之前,必须先取得该表的IX锁

意向锁是InnoDB自动添加的,不需要用户干预

对于UPDATE、DELETE、INSERT语句,InnoDB自动给涉及数据集加排他锁;对于SELECT语句,InnoDB不会加任何锁。




事务 数据 更新 查询 引擎 意向 语句 存储 支持 不同 之间 情况 粒度 机制 优先级 同时 开销 用户 系统 队列 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 同一服务器可以用两个网站吗 人民信息数据库 中文学术资源检索数据库 南京数据库计算机 萤石云为什么一直显示服务器异常 家庭用户能不能自建存储服务器 艾尔登法环有中国服务器 数据库的逻辑删除 网络安全法笔试试卷 怎样用 做app软件开发 服务器安全维护员 网络安全技防措施包括哪些 数据库除重复 数据库及网页程序设计电子书 临西县网络安全委员会 四川浪潮服务器虚拟化哪家便宜 杭州视睿信息科技软件开发 oppo网络安全挑战 广东省网络安全和信息化产业 固原软件开发定做 济宁软件开发学习网站在线学习 一般服务器出厂多久淘汰 中信银行软件开发中心在哪里 重庆系统软件开发哪家正规 kegg数据库别名 数据库原理范式的判断方法 战地5怎么找到之前游玩的服务器 数据库id不从1开始 网络安全五点主张范围 怎样提高局域网的网络安全
0