返回顶部
首页 > 资讯 > 操作系统 >Mariadb之显式使用表锁和行级锁 - Linux
  • 629
分享到

Mariadb之显式使用表锁和行级锁 - Linux

Mariadb之显式使用表锁和行级锁-Linux 2019-01-08 05:01:46 629人浏览 无得
摘要

首先我们来看看mariadb的锁定概念,所谓锁就是当一个进程或事务在操作某一资源时,为了防止其他用户或者进程或事务对其进行资源操作,导致资源抢占而发生冲突,通常在A进程操作该资源时,会对该资源进行加锁,实现多进程或多用户

Mariadb之显式使用表锁和行级锁 - Linux

首先我们来看看mariadb的定概念,所谓锁就是当一个进程或事务在操作某一资源时,为了防止其他用户或者进程或事务对其进行资源操作,导致资源抢占而发生冲突,通常在A进程操作该资源时,会对该资源进行加锁,实现多进程或多用户操作同一资源时,不会发生冲突;通常情况锁的类型分读锁和写锁,所谓读锁就是共享锁,它可以实现多个读操作共享;而写锁就是排它锁,独占锁,一旦加了写锁,其他用户的读写操作将被阻塞,直到该写锁被释放或者因超时而被释放,在其他用户进行的读写操作,此时就会被执行;

  首先我们来看看mariadb的锁定概念,所谓锁就是当一个进程或事务在操作某一资源时,为了防止其他用户或者进程或事务对其进行资源操作,导致资源抢占而发生冲突,通常在A进程操作该资源时,会对该资源进行加锁,实现多进程或多用户操作同一资源时,不会发生冲突;通常情况锁的类型分读锁和写锁,所谓读锁就是共享锁,它可以实现多个读操作共享;而写锁就是排它锁,独占锁,一旦加了写锁,其他用户的读写操作将被阻塞,直到该写锁被释放或者因超时而被释放,在其他用户进行的读写操作,此时就会被执行;对于锁定范围来讲,它又可以分为,表锁和行锁,从字面意思就可以理解到,表锁就是针对整张表所施加的锁,而这种锁定力度相当粗糙,并发相对就比较低,但是维持锁状态锁消耗的成本资源就较小;对于行锁来说,它针对的范围就是行级别所施加的锁,这种锁的粒度就相对要精细,同时并发相对较高,但是维护锁状态消耗的成本资源就相对要大;对于Mysql来讲又锁分为存储引擎级别的锁和mySQL Server级别的锁,存储引擎级别的锁指的是对于何时施加锁或者释放锁由存储引擎自行决定;mysql server级别锁指的是用户使用命令可自行决定施加锁或释放锁;简单讲就是允许用户显式请求加锁或释放锁;显式锁就是用户手动用命令施加的锁,隐式锁指的是由存储引擎根据需要自行施加的锁;对于innodb存储引擎来讲,它支持事务,行级锁;而早期的MyISAM存储引擎它不支持事务,对锁的粒度是表级锁,不支持行级锁;

  显示锁的使用

  1)LOCK TABLES

    指令使用语法:

    LOCK TABLES  tbl_name  read|write, tbl_name read|write, ...

  示例:

  提示:以上语句表示对test_tb这张表施加读锁操作,这意味着其他用户或进程都不能对该表进行写的操作,只能读,因为读锁上共享锁;

  测试:对test_tb表进行写操作,看看是否能够写进去?

  提示:从上面的提示,它告诉我们test_tb这张表施加了读锁,不允许更新;这说明施加读锁,对于写的操作就不能进行;

  测试:对test_tb表进行读操作,看看是否能够进行呢?

  提示:可以看到加了读锁的表,对于读操作上可以继续进行的;

  测试:对test_tb表施加写锁

  提示:释放锁用unlock tables即可释放刚才的读锁;

  测试:对test_tb进行写操作,看看是否能够进行?

  提示:在当前终端(加写锁所在终端)上是可以进行读写操作的;

  测试:在其他终端看看是否能够对test_tb表进行读写操作呢?

  提示:从上面的截图可以看到当我们重新启动一个终端对test_tb进行写操作,它一直处于阻塞状态;

  提示:对于对操作也是同样的效果;一直阻塞着;

  总结:对于施加读锁的表,是可以进行读操作的,但是不能进行写操作,包括当前终端也不能写操作;对于施加写锁的表,在当前施加锁的终端上是可以对其进行读写操作的,但是在别的终端读写操作都将阻塞;

  除了以上指令来对表进行加锁外,还可以使用 flush tables指令来加读锁,具体语法请看下面;

  FLUSH TABLES tbl_name,... [WITH READ LOCK];

  测试:加读锁

  提示:以上flush tables 只能加读锁,不能加写锁;

  行级锁:SELECT cluase [FOR UPDATE | LOCK IN SHARE MODE]

  行级排它锁

  提示:以上红框中的内容就是给第一行加了一个排它锁,这意味着该事务没有提交,其他事务就不能再获取该行的其他锁,包括共享锁和排它锁,但是获取排它锁的事务是可以对数据就行读取和修改。

  提示:可以看到我们重新启动一个事务,然后对第一行进行更新操作,语句就阻塞在哪里了;说明行级排它锁对其他事务来讲是不允许对加锁的行进行写操作;默认情况updeate更新会默认加上排它锁,因为对于第一行来讲,已经有一个排它锁了,所以其他事务就不能对其在加其他锁;而对于select语句来讲,它执行时默认会加任何锁的,所以我们执行select语句是可以正常的查看第一行数据;如果我们在select后面手动加锁,它也会阻塞的;如下

  提示:从上面的截图信息可以看到,我们手动加上排它锁,查询语句也不会顺利执行;从上面信息还可以了解到,我们对第二行也没法进行操作,这又是为什么呢?

  提示:我们查看test_tb这张表上的索引信息,发现没有索引,然后我们在上面创建了一个索引;创建索引时,需要把前面的事务提交了,才可创建成功,否则一直锁在哪里的;接下来我们在创建一个事务,把第一行加上排它锁,然后在对第二行操作看看是否还会一直阻塞呢?

  提示:可以看到当我们创建就了索引后,再对第一行加锁,然后更新第二行就可以正常更新了 ,对第一行还是处于阻塞状态;这说明innodb存储引擎的行级锁的实现其实是依靠其对应的索引,所以如果操作的行并没有用到索引,那么用的还是表级锁。施加行级排它锁后,其他事务将不能对其在施加任何锁;那么对于获取到排它锁的是否能够正常操作呢?

  提示:对于获取到排它锁的事务,是可以正常更新修改的;也可以给对应行施加其他锁;

  行级共享锁

  提示:以上红框中的内容表示给第一行施加共享锁,这意味着在其他事务锁可以共享这把锁看到数据,但是不能更新修改数据;

  测试:在当前事务中更新数据,看看是否可更新?

  提示:在当前事务中是可以正常修改数据的;也能正常查看数据;

  在其他事务中修改数据,看看是否可修改?

  提示:可以看到在其他事务中,就不能对有共享锁的行进行修改操作,但是可以正常读;

  总结:innodb存储引擎的行级锁依赖索引,如果没有索引,就相当于表级锁;对于排它锁来讲,获取到排它锁的事务是可以正常修改更新以及加共享锁,对于没有获取到排它锁的事务,是不能够对有锁的行进行修改更新以及加锁的操作;对于共享锁来讲,对于当前事务(加锁操作的事务)是可以正常修改更新有锁的行,对于其他事务,是不可修改和更新有锁的行;

--结束END--

本文标题: Mariadb之显式使用表锁和行级锁 - Linux

本文链接: https://lsjlt.com/news/6872.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mariadb之显式使用表锁和行级锁 - Linux
    首先我们来看看mariadb的锁定概念,所谓锁就是当一个进程或事务在操作某一资源时,为了防止其他用户或者进程或事务对其进行资源操作,导致资源抢占而发生冲突,通常在A进程操作该资源时,会对该资源进行加锁,实现多进程或多用户...
    99+
    2019-01-08
    Mariadb之显式使用表锁和行级锁 - Linux
  • Mysql锁之行级锁和表级意向锁
    Innodb存储引擎实现了两种行级锁: l   共享锁 l   排他锁 这两种锁之间的兼容关系如下图所示 共享锁 排他锁 ...
    99+
    2024-04-02
  • MySQL的表级锁,行级锁,排它锁和共享锁
    目录前言一、表级锁&行级锁二、排它锁&共享锁1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上三、串行化隔离级别测试前言 如果我们和面试官聊到事务的问题,怎么回答呢? 先说下事务是什么...
    99+
    2022-07-14
    MySQL表级锁 MySQL行级锁 MySQL排它锁 MySQL共享锁
  • MySQL的表级锁,行级锁,排它锁和共享锁是什么
    这篇文章主要介绍“MySQL的表级锁,行级锁,排它锁和共享锁是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL的表级锁,行级锁,排它锁和共享锁是什么”文章能帮助大家解决问题。前言先说下事...
    99+
    2023-07-02
  • mysql行锁和表锁怎么使用
    MySQL中的行锁和表锁是用来控制并发访问数据库的机制,可以防止多个用户同时修改同一行或同一表的数据,保证数据的一致性和完整性。1....
    99+
    2023-09-11
    mysql
  • MySql的行级锁和表级锁是怎样的
    MySql的行级锁和表级锁是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 MySql 行级锁 表级锁如何保...
    99+
    2024-04-02
  • mysql数据库中行级锁、表级锁和页级锁的区别是什么
    这篇文章主要介绍了mysql数据库中行级锁、表级锁和页级锁的区别是什么,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。按粒度可以分为:1、行级锁,MySQL中锁定粒度最细的一种锁,表示只针...
    99+
    2024-04-02
  • InnoDB事务锁之行锁-隐式锁转换显示锁举例理解原理
    ...
    99+
    2024-04-02
  • MySQL的全局锁和表级锁的具体使用
    目录前言全局锁表级锁表锁元数据锁(Metadata Locking,简称:MDL锁)总结参考资料前言 在真实的企业开发环境中使用MySQL,MySQL肯定不会只有我一个人使用,而是一个团队显式的使用MySQL,或者...
    99+
    2022-05-13
    MySQL 全局锁 MySQL 表级锁
  • MySQL使用表锁和行锁的场景详解
    目录前言全局锁表级锁表锁元数据锁意向锁行级锁总结前言 MySQL Innodb 的锁可以说是执行引擎的并发基础了,有了锁才能保证数据的一致性。众所周知,我们都知道 Innodb 有全...
    99+
    2024-04-02
  • MySQL中行锁、页锁和表锁的实际应用
    下面一起来了解下MySQL中行锁、页锁和表锁的实际应用,相信大家看完肯定会受益匪浅,文字在精不在多,希望MySQL中行锁、页锁和表锁的实际应用这篇短内容是你想要的。 MySQL中按照锁的粒度可以细...
    99+
    2024-04-02
  • MySQL表锁、行锁、排它锁及共享锁怎么使用
    这篇文章主要介绍“MySQL表锁、行锁、排它锁及共享锁怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL表锁、行锁、排它锁及共享锁怎么使用”文章能帮助大家解决问题。一、事务隔离机制的选...
    99+
    2023-06-29
  • MySQL表级锁使用说明
    目录表级锁1、表级别的S锁,X锁2、意向锁3、自增锁(AUTO-INC锁)4、元数据锁(MDL锁)表级锁 该锁会锁定整张表,它是mysql中最基本的锁策略,并不依赖于存储引擎(不管你是MySQL的什么存储引擎,对于表锁的...
    99+
    2024-04-02
  • MySQL表锁、行锁、排它锁及共享锁的使用详解
    目录前言一、事务隔离机制的选择二、表级锁&行级锁三、排它锁(Exclusive)和共享锁(Shared)1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上...
    99+
    2024-04-02
  • 怎么使用curator进行分布式加锁
    本篇内容介绍了“怎么使用curator进行分布式加锁”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!多线程情况下对共享资源的操作需要加锁,避免...
    99+
    2023-06-02
  • PHP中使用Redis实现分布式锁升级版
    随着Web应用的发展,分布式架构已经成为了越来越多应用的标配。但是,在分布式架构中,如何保证多个应用同时访问同一资源的互斥性,保证数据的一致性,就成为了每个开发人员需要面对的问题。分布式锁就是一种保证互斥性的解决方案。在PHP语言中,使用R...
    99+
    2023-05-16
    PHP redis 分布式锁
  • SpringBoot之如何使用Redis实现分布式锁
    小编给大家分享一下SpringBoot之如何使用Redis实现分布式锁,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!springboot是什么springboot一种全新的编程规范,其设计目的是用来简化新Spring应用的...
    99+
    2023-06-14
  • SpringBoot之使用Redis实现分布式锁(秒杀系统)
    目录一、Redis分布式锁概念篇1.1、为什么要使用分布式锁1.2、分布式锁应具备哪些条件1.3、分布式锁的三种实现方式二、Redis分布式锁实战篇2.1、导入依赖2.2、配置Red...
    99+
    2024-04-02
  • 解锁样式之谜:使用 HTML 嵌入样式的终极指南
    简介 将样式嵌入 HTML 是在网页中应用样式的一种有效方法。它便于对单个页面进行快速、简单的样式设置,无需使用外部样式表。本文将深入探讨 HTML 中嵌入样式的各种方面,包括基本语法、属性和技巧。 语法 要将样式嵌入 HTML,请使用 ...
    99+
    2024-04-02
  • 如何使用Redis和Java开发分布式锁功能
    如何使用Redis和Java开发分布式锁功能引言分布式锁是在分布式系统中实现互斥访问共享资源的一种机制。在多个节点同时访问共享资源时,需要确保只有一个节点在访问,其他节点需要等待。Redis是一个常用的内存数据库,具备高性能和高可靠性的特点...
    99+
    2023-10-22
    Java redis 分布式锁
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作