iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >深入理解mysql各种锁
  • 950
分享到

深入理解mysql各种锁

2024-04-02 19:04:59 950人浏览 独家记忆
摘要

目录锁的概述锁分类对数据库操作的粒度分对数据操作的类型分Mysql锁不同存储引擎支持锁级别锁介绍MyISAM表锁如何添加表锁加解锁锁竞争锁的使用情况InnoDB锁行锁锁升级间隙锁锁争

锁的概述

锁是计算机协调多个进程或线程并访问某一资源的机制

数据库中,除传统的计算机资源(如cpu、RAM、I/O等)的争用以外,数据也是一种供许多用户共享的资源,如果保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素,从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂

锁分类

对数据库操作的粒度分


表锁:
	操作时,会锁定整个表
行锁:
	操作时,会锁定当前操作行

对数据操作的类型分


读锁(共享锁):
	针对同一份数据,多个读操作可以同时进行而不会相互影响
写锁(排它锁):
	当操作没有完成之前,它会阻断其他写锁和读锁

mysql

相对其他数据库而言,Mysql的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。

不同存储引擎支持锁级别

存储引擎 表级锁 行级锁 页面锁
MyISAM 支持 不支持 不支持
InnoDB 支持 支持 不支持
MEMORY 支持 不支持 不支持
BDB 支持 不支持 支持

锁介绍

很难笼统说哪种锁更好,需要根据特定的应用场景来分析哪种锁更合适。

锁类型 特点
表级锁 偏向MyISAM存储引擎,开销小,加锁快;不会出现死锁;锁定粒度大,发送锁冲突的概率最高,并发度最低。
行级锁 偏向InnoDB存储引擎,开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
页面锁 开销和加锁时间介于表锁和行锁之间;会出现死锁;锁定粒度介于表锁和行锁之间,并发度一般。

MyISAM表锁

如何添加表锁


MyISAM在执行查询语句(select)前,会自动给涉的所有表加锁,在执行更新操作(update、delete、insert等)前,会自动给涉及的表加写锁,这个过程并不需要用户干预,因此,用户一般不需要直接使用LOCK TABLE命令给MyISAM表显示加锁

加解锁


加读锁:
	lock table table_name read; 
	---解锁 unlock tables;
加写锁:
	lock table table_name write;
	添加写锁当前会话可以读写操作,别的会话会处于阻塞(等待)状态
读锁限制写,写锁限制读写

锁竞争


1、对MyISAM表的读操作,不会阻塞其他用户对同一表的读请求,但会阻塞对同一表的写请求;
2、对MyISAM的写操作,则会阻塞其他用户对表一表的读和写操作;
3、MyISAM锁调度是写优先。
	不适合作为主表,写锁后其他线程大量的更新会使查询很难得到锁,可能会造成永远阻塞。

锁的使用情况


查看锁的使用情况
	show open tables;
查看表的锁定情况
	show status like 'table_locks%';
		Table_locks_immediate:可以获取表级锁的次数,每立即获取锁,值加1
		Table_locks_waited:不能立即获取锁需要等待的次数,每等待一次,值加1,可以判断比较严重的表级锁争用情况
	

InnoDB锁

InnoDB与MyISAM的最大不同有亮点:一是支持事务;二是采用行级锁

行锁


共享锁:
	又称读锁,多个事务可以共享一把锁,但是只能读,不能写
排它锁:
	又称写锁,锁不共用,获取不到锁的事务不能进行读写操作
如果进行update、delete和insert 语句,innoDB会自动给涉及数据集加排它锁
对不同的select语句不会添加任何锁
显示的给查询添加锁
	添加共享锁:
		select * from table_name where ... Lock IN SHARE MODE
	添加排它锁:
		select * from table_name where ... FOR UPDATE

锁升级


索引失效,行锁升级表锁
where后面没索引也升级为表锁

间隙锁

InnoDB会对间隙不存在的数据也会加锁,称之为间隙锁

锁争用


show status like 'innodb_row_lock%';
	Innodb_row_lock_current_waits当前正在等待锁的数量
	Innodb_row_lock_time 锁定的总时长
	Innodb_row_lock_time_avg 锁定的平均时长
	Innodb_row_lock_time_max 锁定的最大时长
	Innodb_row_lock_waits 系统启动到现在总共等待次数

总结

innoDB存储引擎实现了行锁,虽然锁定机制的实现方面带来了性能消耗可能比较表锁会更高些,但是在整体并发处理能力方面要远优于MyISAM表锁,当系统并发比较高的时候,InnoDB的整体性能和MyISAM会有比较明显的优势

优化建议


尽可能让所有数据检索都能通过索引来完成,避免无索引行锁升级为表锁
合理设计索引,尽量缩小锁的范围
尽可能减少索引条件,及索引范围,避免间隙锁
尽量控制事务大小,减少锁定资源量和时间的长度
尽可能使用低级别事务隔离(需要业务能满足需求)

到此这篇关于深入理解mysql各种锁的文章就介绍到这了,更多相关mysql锁内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: 深入理解mysql各种锁

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 深入理解mysql各种锁
    目录锁的概述锁分类对数据库操作的粒度分对数据操作的类型分mysql锁不同存储引擎支持锁级别锁介绍MyISAM表锁如何添加表锁加解锁锁竞争锁的使用情况InnoDB锁行锁锁升级间隙锁锁争...
    99+
    2022-11-12
  • 怎样深入理解mysql各种锁
    怎样深入理解mysql各种锁,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。锁的概述锁是计算机协调多个进程或线程并访问某一资源的机制在数据库中,除传统的计算机资源(如cpu、RA...
    99+
    2023-06-21
  • 深入解析MySQL中的各种锁机制
    MySQL 各种锁详解一、引言在并发访问中,数据库需要使用锁来保护数据的一致性和完整性。MySQL 提供了多种类型的锁,包括共享锁、排他锁、意向共享锁、意向排他锁等。本文将使用具体的代码示例介绍并解析这些锁的使用方式和特点。二、共享锁(Sh...
    99+
    2023-12-21
    MySQL - 事务 - 行锁 - 表锁
  • 【史上最全】MySQL各种锁详解:一文搞懂MySQL的各种锁
    前言 锁在 MySQL 中是非常重要的一部分,锁对 MySQL 的数据访问并发有着举足轻重的影响。锁涉及到的知识篇幅也很多,所以要啃完并消化到自己的肚子里,是需要静下心好好反反复复几遍地细细品味。本文是对锁的一个大概的整理,一些相关深...
    99+
    2023-09-11
    数据库 mysql java 编程语言 面试
  • 深入理解java各种集合的线程安全
    线程安全首先要明白线程的工作原理,jvm有一个main memory,而每个线程有自己的workingmemory,一个线程对一个variable进行操作时,都要在自己的workingmemory里面建立一个copy,操作完之后再写入mai...
    99+
    2017-12-26
    java入门 java 线程安全
  • GolangMutex互斥锁深入理解
    目录引言Mutex结构饥饿模式和正常模式正常模式饥饿模式状态的切换加锁和解锁加锁自旋计算锁的新状态更新锁状态解锁可能遇到的问题锁拷贝panic导致没有unlock引言 Golang的...
    99+
    2022-11-11
  • 深入理解 MySQL ——锁、事务与并发控制
    本文首发于vivo互联网技术微信公众号作者:张硕本文对 MySQL 数据库中有关锁、事务及并发控制的知识及其原理做了系统化的介绍和总结,希望帮助读者能更加深刻地理解 MySQL 中的锁和事务,从而在业务系...
    99+
    2022-10-18
  • mysql中的锁机制深入讲解
    前言 为了保证数据的一致完整性,任何一个数据库都存在锁定机制。锁定机制的优劣直接应想到一个数据库系统的并发处理能力和性能,所以锁定机制的实现也就成为了各种数据库的核心技术之一。 大概几个月之前项目中用到事...
    99+
    2022-10-18
  • 深入了解Java中Synchronized的各种使用方法
    目录Synchronized关键字Synchronized修饰实例方法Synchronized修饰静态方法Sychronized修饰多个方法Synchronized修饰实例方法代码块...
    99+
    2022-11-13
    Java Synchronized用法 Java Synchronized Java Synchronized使用
  • MySQL InnoDB中的锁机制深入讲解
    写在前面 数据库本质上是一种共享资源,因此在最大程度提供并发访问性能的同时,仍需要确保每个用户能以一致的方式读取和修改数据。锁机制(Locking)就是解决这类问题的最好武器。 首先新建表 test,其...
    99+
    2022-10-18
  • 深入理解MySQL事务的4种隔离级别
    目录1 简介2 什么是数据库事务?2.1 事务的四大特性(ACID)3 并发事务会导致的问题3.1 本文会使用到的 SQL 语句3.1.1 示例表结构3.1.2 查询事务的默认隔离级...
    99+
    2022-11-13
  • MySQL锁机制的深度理解
    深入理解 MySQL 锁机制,需要具体代码示例MySQL 是当今最流行的关系型数据库之一,其优秀的性能和可靠性使得它广泛应用于各个行业的数据存储和管理。在多用户并发访问的情况下,MySQL 的锁机制扮演着至关重要的角色,它能够保证数据的一致...
    99+
    2023-12-21
    MySQL 机制
  • 详解MySql中InnoDB存储引擎中的各种锁
    目录什么是锁InnoDB存储引擎中的锁锁的算法行锁的3种算法幻像问题锁的问题脏读不可重复读丢失更新死锁什么是锁 现实生活中的锁是为了保护你的私有物品,在数据库中锁是为了解决资源争抢的...
    99+
    2022-11-13
  • 深入理解MySQL索引
    前言 当提到MySQL数据库的时候,我们的脑海里会想起几个关键字:索引、事务、数据库锁等等,索引是MySQL的灵魂,是平时进行查询时的利器,也是面试中的重中之重。 可能你了解索引的底层是b+树,会加快查询,也会在表中建立索引,但这是远远不够...
    99+
    2017-02-27
    深入理解MySQL索引
  • 深入聊聊MySQL中各种对象的大小长度限制
    目录标识符的长度限制权限表中范围字段的长度限制数据库和表的数量限制表大小的限制字段数量和数据行大小的限制字段数量限制数据行大小限制数据行大小限制示例总结今天给大家介绍一下 MySQL...
    99+
    2022-11-12
  • 如何理解mysql的各种日志
    这篇文章将为大家详细讲解有关如何理解mysql的各种日志,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。mysql错误日志: 错误日志记录的事件:a)、服...
    99+
    2022-10-19
  • 深入理解java内置锁(synchronized)和显式锁(ReentrantLock)
    synchronized 和 Reentrantlock多线程编程中,当代码需要同步时我们会用到锁。Java为我们提供了内置锁(synchronized)和显式锁(ReentrantLock)两种同步方式。显式锁是JDK1.5引入的,这两种...
    99+
    2023-05-30
    java 内置锁 synchronized
  • JavaScript中各种二进制对象关系的深入讲解
    目录前言各种对象的关系ArrayBufferTypedArrayUint8ClampedArray字符的相互转换DataViewBlobURL数据读取FileFileListFile...
    99+
    2022-11-12
  • mysql 间隙锁原理深度详解
    目录 一、前言 二、mysql之mvcc 2.1 什么是mvcc 2.2 mvcc组成 2.2.1 Undo log 多版本链 2.2.2 ReadView 2.2.3 快照读与当前读 三、RR级别下的事务问题 3.1 RR隔离级别解决的问...
    99+
    2023-08-31
    mysql间隙锁 间隙锁 mysql可重复读
  • 深入理解hibernate的三种状态
    学过hibernate的人都可能都知道hibernate有三种状态,transient(瞬时状态),persistent(持久化状态)以及detached(离线状态),大家伙也许也知道这三者之间的区别,比如瞬时状态就是刚new出来一个对象,...
    99+
    2023-05-31
    hibernate 三种状态 te
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作