Mysql锁初步

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 存储引擎 要了解mysql的锁,就要先从存储引擎说起。 常用存储引擎列表如下图所示:   最常使用的两种存储引擎: Myisam是Mysql的默认存储引擎。当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。

存储引擎

要了解mysql的锁,就要先从存储引擎说起。

常用存储引擎列表如下图所示:

 

最常使用的两种存储引擎:

  • Myisam是Mysql的默认存储引擎。当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。每个MyISAM在磁盘上存储成三个文件。文件名都和表名相同,扩展名分别是.frm(存储表定义)、.MYD (MYData,存储数据)、.MYI (MYIndex,存储索引)。数据文件和索引文件可以放置在不同的目录,平均分布io,获得更快的速度。   
  • InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。

PS:可以在create table语句括号之后结束之前通过如下方式指定存储引擎:

ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='这个表使用的是MyISAM'存储引擎。

 

各个引擎的适用环境:

  1. MyISAM:默认的MySQL插件式存储引擎,它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一
  2. InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。
  3. Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。
  4. Merge:允许MySQL DBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。

 

mysql相关指令:

查看mysql支持的所有存储引擎:
> show engines;
查看当前mysql所使用的存储引擎:
> show variables like '%storage_engine%';
查看表使用的存储引擎
a、show table status from db_name where name='table_name';
b、show create table table_name;

关闭Innodb引擎方法:
1、关闭mysql服务: net stop mysql
2、 找到mysql安装目录下的my.ini文件:
将default-storage-engine=INNODB改为default-storage-engine=MYISAM
将#skip-innodb的注释去掉,改为skip-innodb
3、启动mysql服务:net start mysql

cmd下远程连接其他的mysql:

-u root -h 10.16.70.160 -p

 

 

Mysql的默认调度和锁定策略:
写入操作优先于读取操作。对某张数据表的写入操作某一时刻只能发生一次,写入请求按照它们到达的次序来处理。对某张数据表的多个读取操作可以同时地进行。
对某张数据表的多个读取操作可以同时地进行。

 

共享锁和排他锁:

共享锁:

用法: select * lock in share mode;
锁申请的前提:
当申请的记录没有被排他锁锁定的时候才可以进行申请。
操作限制:

线程    读取操作    写入操作                  共享锁申请          排他锁申请
使用共享锁的线程     可读   可写/不可写(报错)  可申请   可申请
不使用共享锁的线程    可读    不可写(阻塞)   可申请   不可申请(阻塞)


                     
                        
                                 
PS:

1. 此时使用共享锁和不使用共享锁的线程读取到的数据是同一个版本。
2. 对于写入操作,使用共享锁的线程需要分情况讨论,当只有当前线程对指定记录使用共享锁时,线程是可对该记录进行写入操作(包括更新与删除),这是由于在写入操作前,线程向该记录申请了排他锁,然后才进行写入。当其他线程也对该记录使用共享锁时,则不可进行写入操作,系统会有报错提示。不对锁定记录使用共享锁的线程,当然是不可进行写入操作了,写入操作会阻塞。
3. 直接在mysql中输入select * lock in share mode;会发现另一个连接仍然可以修改数据,这是应为mysql设置的默认autocommit标志为1,其实执行完这一句之后锁就释放了。
应该通过事务来进行处理,即 begin 、 commit . 这一点对于排他锁也适用。

排他锁:
用法: SELECT ... FOR UPDATE;
锁申请前提:当前没有线程对该结果集中的任何行使用排他锁或共享锁,否则申请会阻塞。

线程    读取操作    写入操作                  共享锁申请          排他锁申请
使用排他锁的线程    可读(新版本)   可写  可申请   可申请
不使用排他锁的线程   可读(旧版本)   不可写(阻塞)   不可申请(阻塞)   不可申请(阻塞)


                     
                        
          

在事务的操作中任何对记录的更新和删除操作会自动加上排他锁


Mysql官方文档对于共享锁和排他锁的说明:
SELECT ... LOCK IN SHARE MODE sets a shared mode lock on the rows .A shared mode lock enables other sessions to read the rows but not to modify them.
The rows read are the latest available, so if they belong to another transaction that has not yet the read blocks until that transaction ends.

SELECT ... FOR UPDATE sets an exclusive lock on the rows .An exclusive lock prevents other sessions from accessing the rows for reading or writing.

(注意快照读是可以的但是不允许申请共享锁读)

PS: 对于排他锁和共享锁如果不是按照主键作为where条件,最终加锁的还是整个表而不是单条记录

 

Mysql锁之行锁:

行锁是Mysql中力度最小的锁。MyIsam引擎只支持表级锁,innodb支持行级锁。行级锁拥有最大的并发支持特性但是实现成本也比较高,也比较容易造成死锁。
Innodb的行级锁分为共享锁和排他锁。共享锁允许事务读一行记录但是不允许任何线程对该记录进行修改。排他锁允许事务更新或者删除一行记录,其他线程不许操作该记录。

当然前提是必须适用主键作为查询条件。

 

 以上只是mysql锁的初步入门,更多锁的知识,还得继续深入!

 

 

黎明前最黑暗,成功前最绝望!
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
MySQL 锁
MySQL里常见的几种锁
59 3
|
3月前
|
存储 关系型数据库 MySQL
优化 MySQL 的锁机制以提高并发性能
【10月更文挑战第16天】优化 MySQL 锁机制需要综合考虑多个因素,根据具体的应用场景和需求进行针对性的调整。通过不断地优化和改进,可以提高数据库的并发性能,提升系统的整体效率。
160 1
|
3月前
|
关系型数据库 MySQL Java
MySQL数据锁:Record Lock,Gap Lock 和 Next-Key Lock
本文基于 MySQL 8.0.30 版本及 InnoDB 引擎,深入解析三种行锁机制:记录锁(Record Lock)、间隙锁(Gap Lock)和临键锁(Next-key Lock)。记录锁锁定索引记录,确保事务唯一修改;间隙锁锁定索引间的间隙,防止新记录插入;临键锁结合两者,锁定范围并记录自身,有效避免幻读现象。通过具体示例展示了不同锁的作用机制及其在并发控制中的应用。
306 2
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库锁:共享锁和独占锁
本文详细介绍了`InnoDB`存储引擎中的两种行级别锁:共享锁(S锁)与排他锁(X锁)。通过具体示例展示了这两种锁的工作机制及其在`InnoDB`与`MyISAM`引擎中的表现差异。文章还提供了锁的兼容性矩阵,帮助读者更好地理解锁之间的互斥关系。最后总结了两种锁的特点及适用场景。适合希望深入了解`MySQL`并发控制机制的读者阅读。
101 1
|
4月前
|
监控 关系型数据库 MySQL
MySQL锁机制与解决死锁问题
MySQL锁机制与解决死锁问题
364 5
|
3月前
|
存储 关系型数据库 MySQL
MySQL锁,锁的到底是什么?
【10月更文挑战第16天】MySQL 锁锁定的是与数据和资源相关的对象,其目的是为了保证数据的一致性、避免冲突,并在并发环境下合理协调事务或操作的执行。理解锁的对象和意义对于优化数据库性能、处理并发问题至关重要。
105 0
|
3月前
|
关系型数据库 MySQL 数据库
mysql锁详解
通过理解并合理运用MySQL中的锁机制,开发者可以有效管理数据库并发访问,平衡性能与数据一致性需求。更多关于MySQL锁的深入探讨和最佳实践,请参考专业的数据库管理资源[[深入MySQL锁机制详解
64 0
|
4月前
|
关系型数据库 MySQL 数据库
Mysql的锁
本文介绍了MySQL中表级锁和行级锁的区别,其中MyISAM仅支持表级锁,而InnoDB支持表级锁和行级锁,默认为行级锁。表级锁锁定整个表,实现简单,资源消耗少,但并发度低;行级锁仅锁定相关记录,减少冲突,提高并发度,但加锁开销大。此外,还介绍了共享锁和排他锁的概念及意向锁的作用。
|
4月前
|
存储 SQL 关系型数据库
MySQL 的锁机制,那么多的锁,该怎么区分?
MySQL 的锁机制,那么多的锁,该怎么区分?
52 0
|
5月前
|
监控 关系型数据库 MySQL
在Linux中,mysql的innodb如何定位锁问题?
在Linux中,mysql的innodb如何定位锁问题?