美文网首页
高性能 Mysql 第一章第二节 并发控制

高性能 Mysql 第一章第二节 并发控制

作者: 与子笑 | 来源:发表于2020-09-11 15:02 被阅读0次

提出问题

本章节内容开篇先提出问题,我们简化这个问题。假设有一个单向链表,每一个单元记录着上一个单元的key,每一个单元且只有一个值。

那么如果有两个客户端同时向这个链表追加一个值得时候,会发生什么。显然这个就是并发问题了。本章节粗略介绍了 MYSQL 是如何解决这个问题的。

解决思路

解决问题的办法就是加锁。根据锁类型来分,分为两种,而这两种锁,在外界有太多的说法。
而本书使用的名词,叫读锁(Read Lock,S锁,共享锁,都是指的同一种),写锁(Write Lock,X锁,排它锁),更标准的做法,其实就是叫读,写锁。

共享锁与排它锁这两个叫法实际来源于这两种锁的特征。

思考

在本章节,没有去描述锁技术的具体实现,也只是非常浅的描述了这两种锁的区别,即对数据片加上写锁后,其他用户不允许对该数据片进行读和写。对数据片加上读锁后,其他用户也可以对该数据片进行读取,但是不可以进行写操作。

在这里,本章节描述到:
对数据库来说,随时随地都会发生锁定。当某一用户修改某一部分数据的时候,Mysql 会禁止其他用户读取同一数据,大多数时候,Mysql 都是以透明的方式来实现锁的管理。

在此之前,我在看视频的时候,那个讲师说到过,为什么大多数时候,我们不去加锁,不去用事务,程序也能正常运行?那是因为 Mysql 默认替我们做了那些事情。

然后在上一章节中也有提到过,服务器通过存储引擎 API 与引擎进行通讯,这个 API 接口对于查询层上来说是透明的。

可以看出Mysql会默认在大多数时候会对数据自动进行加锁(当然这中间是有根据查询语句判断加什么锁的)。

以上是对锁的类型进行了分类的简单说明,后面说到了锁粒度进行了说明,只写了两种,即表锁和行锁(书中介绍到这两种锁是最重要的锁策略)。

锁粒度

加锁是为了防止在并发状态下的数据冲突,而加锁也会带来性能上的消耗,每一种锁都会有三种操作,即检查锁,获得锁,释放锁,都是开销。

每一种锁粒度带来的消耗也不一样,开销也会不一样。提高共享资源的并发性就是让锁定数据片对象更有选择性,即只对要修改的数据片进行加锁

开销最小的是表锁。行锁开销最大。表锁是由服务器实现的,而行锁是由存储引擎实现的。出现并发读写状况的话,写锁的优先级要高于读锁。

服务器是完全不了解存储引擎的锁实现方式的。虽然存储引擎管理自己的锁。

但是 Mysql 本身也能使用各种有效的表锁,例如在一些情况下,Mysql服务器会自动选择表锁,而不用去考虑存储引擎用的什么锁。

例如 alter table,进行表的结构处理,会自动为这个语句加上表写锁,防止并发情况下的数据冲突。

原文链接: 高性能 Mysql 第一章第二节 并发控制

相关文章

  • 1. 高性能MySQL(第三版) -目录

    第一章 MySQL架构与历史 1.1 MySQL逻辑架构 1.2 开发控制 1.3 事务 1.4 多版本并发控制 ...

  • MySQL系列之三 -- -并发(MVCC)

    MySQL 并发控制如何实现 MySQL 如何实现高并发? 一 并发控制 抛开MySQL,通过技术上来讨论并发控制...

  • 高性能 Mysql 第一章第二节 并发控制

    提出问题 本章节内容开篇先提出问题,我们简化这个问题。假设有一个单向链表,每一个单元记录着上一个单元的key,每一...

  • 《高性能MySQL》&《MySQL技术内幕 InnoDB

    《高性能MySQL》&《MySQL技术内幕 InnoDB存储引擎》笔记 第一章 MySQL架构与历史 MySQL的...

  • MySQL笔记-锁、事务与并发控制

    MySQL服务器逻辑架构 MySQL并发控制 MySQL死锁问题 MySQL中的事务

  • 你应该了解的MySQL锁分类

    MySQL中的锁 锁是为了解决并发环境下资源竞争的手段,其中乐观并发控制,悲观并发控制和多版本并发控制是数据库并发...

  • MySQL并发控制

    MySQL在处理并发读或者写时,可以通过实现一个有两种类型的锁组成的锁系统来解决问题。这两种类型的锁通常被...

  • MySQL -- 并发控制

    无论何时,只要有多个查询需要在同一时刻修改数据,都会产生并发控制的问题,解决这类经典总是的方法就是并发控制,其实非...

  • mysql并发控制

    在出现多个用户同一时间对用一个表进行读写的时候可能会出现,用户1读取表1同时用户2修改表1或者用户1读取表1同时用...

  • MySQL并发控制

    如果数据库中的所有事务都是串行执行的,那么它非常容易成为整个应用的性能瓶颈,虽然说没法水平扩展的节点在最后都会成为...

网友评论

      本文标题:高性能 Mysql 第一章第二节 并发控制

      本文链接:https://www.haomeiwen.com/subject/fiqejktx.html