我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中并发控制的原理是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中并发控制的原理是什么

mysql中并发控制的原理是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

1、mysql的逻辑框架

mysql逻辑框架图如下:

mysql中并发控制的原理是什么

最上层是处理客户端过来的连接的。

主要做连接处理、授权认证、安全等。Mysql在这一层维护了一个线程池,用于处理来自客户端的连接。Mysql可以使用用户名密码认证,

也可以使用SSL基于X.509证书认证。

第二层由三部分组成:查询缓存、解析器、优化器。解析器用来解析SQL语句,优化器会对解析之后的语句进行优化。

在解析查询前,服务器会先检查查询缓存,如果能在其中找到对应的查询结果,则无需再进行查询解析、优化等过程,直接返回查询结果。存储过程、触发器、视图等都在这一层实现。

第三层是存储引擎,存储引擎负责在MySQL中存储数据、提取数据、开启一个事务等等。存储引擎通过API与上层进行通信,这些API屏蔽了不同存储引擎之间的差异,使得这些差异对上层查询过程透明。存储引擎不会去解析SQL。mysql最常用的存储引擎是InnoDB。

2、mysql的并发控制

如果多个线程同时操作数据,就有可能引发并发控制的问题。

2-1、读写锁

如果多个线程都只是读数据,其实可以一起读,不会互相影响,这个时候应该使用“读锁”,也称为共享锁。

获取读锁的线程之间互相不会阻塞,可以同时读取一个资源。

如果有一个线程需要写数据,则应该使用“写锁”,也成为排它锁。

写锁会阻塞其它的写锁和读锁,直至写操作完成。

2-2、锁粒度

首先明确一个概念:在给定的资源上,需要加锁的数据越少,系统能够承载的并发量就越高。

但加锁也是需要消耗资源的,如果系统花费大量的时间来管理锁,而不是存取数据,

那么系统的性能可能会因此受影响。

所以一个好的“锁策略”就是要在锁的开销和数据的安全性之间寻求平衡,Mysql支持多个存储引擎的架构,

每种存储引擎都可以实现自己的锁策略和锁粒度。

2-3、表锁和行锁

表锁顾名思义就是锁住整张表。表锁开销比较小。对表加写锁后,其它用户对这张表的所有读写操作都会被阻塞。

在Mysql中,尽管存储引擎可以提供自己的锁,但Mysql有时候也会使用表锁,比如ALTER TABLE之类的语句。

写锁比读锁有更高的优先级,因此一个写锁请求可能会插入到读锁队列的前面。

行级锁即锁住整行,可以最大程度地支持并发处理,但加解锁的开销也会比较大。行级锁只在储存引擎层实现,

所有的存储引擎都以自己的方式实现了行级锁。

3、MVCC

MVCC即“多版本并发控制”,可以认为MVCC是行级锁的一个变种,但是它在很多情况下避免了加锁操作,

因此开销更低。

主流的关系型数据库都实现了MVCC,但实现机制各有不同。实际上MVCC也没有一个统一的标准。

但大都实现了非阻塞的读操作,写操作也只是锁定必要的行。

MVCC保证的是每个事务里面在执行期间看到的数据都是一致的。

但不同的事务由于开始的时间不同,所以可能对同一张表,同一时刻看到的数据是不一样的。

在Mysql的InnoDB引擎,是通过给每行记录后面保存两个隐藏的列来实现的。

一个是保存行的创建时间,另一个保存了行的过期时间(或删除时间)。

实际上存储的并不是实际的一个时间戳,而是‘系统版本号'。

每次开启一个事务,系统版本号都会递增。事务开始时,系统版本号会作为事务的版本号,用来和查询到的行的版本号进行比较。

下面分别介绍常见的CRUD操作中版本号是怎么工作的:

INSERT

保存当前系统版本好的作为行版本号

DELETE

保存当前的系统版本号到这行数据的“删除版本”。

UPDATE

插入一行新纪录,保存当前系统版本号作为航版本号,同时保存当前系统版本号到原来的行的“删除版本”。

SELECT

只查找版本早于当前事务版本的行。这样可以保证事务读取的行,要么之前就存在,

要么是这个事务本身自己插入或者修改的。

行的“删除版本”要么未定义,要么大于当前事务版本号。这样可以确保事务读取到的行,

在事务之前没有被删除。

MVCC只在REPEATABLE READ和READ COMMITTED两个隔离级别下工作,其它两个隔离级别不能工作。

因为READ UNCOMMITTED总是读取最新的数据防,而不是符合当前事务版本的数据行。而SERIALIZABLE则会对所有读取的行都加锁。

关于mysql中并发控制的原理是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中并发控制的原理是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL MVCC 原理解析:为什么是并发控制的最佳选择?

MySQL MVCC 原理解析:为什么是并发控制的最佳选择?在关系型数据库中,数据的一致性和并发控制是至关重要的。MySQL作为最流行的关系型数据库管理系统之一,采用了MVCC(Multi-Version Concurrency Contr
2023-10-22

NoSQL中乐观并发控制和悲观并发控制的区别是什么

在NoSQL数据库中,乐观并发控制和悲观并发控制是两种常见的并发控制策略。乐观并发控制:乐观并发控制假设冲突的概率较低,并允许多个事务同时对数据进行读写操作。当一个事务要修改数据时,先读取数据并记录版本号或时间戳,然后在写入时检查是否有其
NoSQL中乐观并发控制和悲观并发控制的区别是什么
2024-05-07

Java并发编程中并发机制的底层实现原理是什么

今天就跟大家聊聊有关Java并发编程中并发机制的底层实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java中的并发机制依赖于JVM的实现和CPU指令,接下来我们深入底层
2023-06-19

golang并发控制的方法是什么

在Go语言中,可以使用以下几种方法来控制并发:1. Goroutine:Goroutine是Go语言中的轻量级线程,可以通过go关键字创建。可以使用goroutine来实现并发执行的代码块。2. Channel:Channel是Gorout
2023-10-20

MongoDB的并发控制与锁机制是什么

MongoDB使用乐观并发控制(Optimistic Concurrency Control)来处理并发操作。在MongoDB中,并发操作通过基于文档级别的锁来实现。当一个客户端请求对一个文档进行更新时,MongoDB会先获取该文档的锁,然
MongoDB的并发控制与锁机制是什么
2024-05-07

golang控制并发数的方法是什么

在Golang中,可以使用goroutine和channel来控制并发数。以下是几种常见的方法:通过控制goroutine的数量:可以使用sync.WaitGroup来等待一组goroutine的完成。在每个goroutine启动之前,可以
2023-10-27

Mysql中MVCC机制的原理是什么

这篇文章将为大家详细讲解有关Mysql中MVCC机制的原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Mysql的锁和事务隔离级别在理解MVCC机制的原理之前,需要先理解Mysql的
2023-06-14

mysql中WAL机制的原理是什么

mysql中WAL机制的原理是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、WAL预写日志系统。数据库中的高效日志算法,对于非内存数据库来说,磁盘I/O
2023-06-20

MySQL 并发控制中的锁策略

MySQL 锁的并发控制策略引言:在数据库系统中,为了保证数据的一致性和完整性,需要对并发操作进行控制。而锁机制是一种常用的并发控制策略。MySQL作为一种常用的关系数据库管理系统,也拥有自己的锁机制,下面我们就来详细了解MySQL锁的并发
MySQL 并发控制中的锁策略
2023-12-21

Node高并发的原理是什么

这篇文章主要介绍“Node高并发的原理是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Node高并发的原理是什么”文章能帮助大家解决问题。从头聊起一个常见web应用会做哪些事情运算(执行业务逻辑
2023-07-04

MySQL的多版本并发控制MVCC实现方法是什么

这篇文章主要讲解了“MySQL的多版本并发控制MVCC实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的多版本并发控制MVCC实现方法是什么”吧!什么是MVCCMVCC
2023-06-22

编程热搜

目录