热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:MySQL有关锁的简单介绍

篇首语:本文由编程笔记#小编为大家整理,主要介绍了MySQL有关锁的简单介绍相关的知识,希望对你有一定的参考价值。一、Latch&Lock 

篇首语:本文由编程笔记#小编为大家整理,主要介绍了MySQL 有关锁的简单介绍相关的知识,希望对你有一定的参考价值。



一、Latch & Lock 

在数据库中 Latch & Lock 都可以被称为锁,但两者有着截然不同的意义。

Latch 一般被称为闩锁(轻量级的锁),锁定的时间很短,若持续的时间长,则应用的性能会非常差。

在 InnoDB 中 Latch 锁又可以分为 mutex (互斥量) 和 rwlock (读写锁)。其主要目的是用来保证并发线程操作临界资源的正确性,并且没有死锁检测机制。

## Latch 是一个非常透明的东西,一般除了非常底层的数据库人员很难看懂

## show engine innodb mutex;

Lock 的对象是事务,用来锁定的数据库中的对象,如表,页,行。一般 Lock 的对象仅在事务 commit 或rollback 后进行释放(不同事务隔离级别释放的时间可能不同)。Lock 与 Latch 不同的是 Lock 有死锁检测机制的。


二、InnoDB 存储引擎中的锁

一、InnoDB 存储引擎中的锁:

S 行级共享锁:允许事务读一行数据;lock in share mode。

X 行级排他锁 :  允许事务更新或删除一行数据;增删改产生排它锁,还有一个比较特殊 select ... for update。

IS : 意向锁

IX : 意向排他锁

AI : 自增锁,AI 自增锁 ,自增锁是用来做自增的并发控制的。


二、锁之间的兼容性

锁兼容(Lock Compatible): 如果事务T1 获得行 r 的共享锁,那么另外的事务 T2 可以立即获得行 r 的共享锁,因为读取并没有改变行 r 的数据。

锁不兼容: 若有其他的事务 T3 想获得行 r 的排他锁,则必须等待事务 T1、T2 释放行 r 上的共享锁。

              表 1-1 排它锁和共享锁的兼容性

从表1-1 可以看出 ,X锁与任何的锁都不兼容,而 S 锁仅和 S 锁兼容。S 锁 和 X 锁都是行锁 ,兼容是指对同一记录(row)锁的兼容情况。

意向锁: 用来实现多粒度级别的锁的。

  揭示下一层级请求的锁类型。

  IS : 事务想要获得一张表中某几行的共享锁

  IX : 事务想要获得一张表中某几行的排它锁

InnoDB 中意向锁都是表锁(简单的这样理解下)

数据库总共有表锁,页锁,记录锁,但是在 mysql 中只有表锁跟记录锁,意向锁都是加在表上的。

意向锁之间都是兼容的,用来揭示下一层级的锁。

              表 1-2 InnoDB 存储引擎中锁的兼容性


 三、查看锁对象内容

使用 show engine innodb status 


(root@localhost) [(none)]> pager less
PAGER set to \'less\'
(root@localhost) [(none)]>
(root@localhost) [(none)]> show engine innodb status \\G
TRANSACTIONS
------------

 

 

 如果想查看比较详细的锁的信息,可通过开启 innodb_status_output_locks  


(root@localhost) [test]> set global innodb_status_output_locks=1;
Query OK,
0 rows affected (0.00 sec)
(root
@localhost) [test]> show variables like \'%innodb_status_output%\';
+----------------------------+-------+
| Variable_name | Value |
+----------------------------+-------+
| innodb_status_output | OFF |
| innodb_status_output_locks | ON |
+----------------------------+-------+
2 rows in set (0.00 sec)

如下是开启 innodb_status_output ,show engine innodb status 输出的详细信息:

找到 TRANSACTIONS , heap_no 2,3,4 表示的是插入的顺序,其中包含两个隐藏列, len 6 是指针列,len 7 是什么列来着忘了

在 show engine innodb status 中的 thread_id 对应的是 show processlist 中 processlist_id 。

这样看有点麻烦,可以借助 information_schema 中的几张表,innodb_trx,innodb_locks,innodb_lock_waits

在 5.7 版本中有一张 innodb_lock_waits 


(root@localhost) [sys]> select * from innodb_lock_waits\\G
*************************** 1. row ***************************
wait_started:
2019-02-28 16:26:18
wait_age:
00:00:18
wait_age_secs:
18
locked_table: `test`.`lock_1`
locked_index:
PRIMARY
locked_type: RECORD
waiting_trx_id:
260217
waiting_trx_started:
2019-02-28 16:26:18
waiting_trx_age:
00:00:18
waiting_trx_rows_locked:
1
waiting_trx_rows_modified:
0
waiting_pid:
18
waiting_query:
update lock_1 set b=6 where a=4
waiting_lock_id:
260217:217:3:3
waiting_lock_mode: X
blocking_trx_id:
260213
blocking_pid:
19
blocking_query:
NULL
blocking_lock_id:
260213:217:3:3
blocking_lock_mode: X
blocking_trx_started:
2019-02-28 16:11:46
blocking_trx_age:
00:14:50
blocking_trx_rows_locked:
1
blocking_trx_rows_modified:
0
sql_kill_blocking_query:
KILL QUERY 19
sql_kill_blocking_connection:
KILL 19
1 row in set, 3 warnings (0.00 sec)


 # kill query :表示杀掉查询,

 # kill 表示这个连接也杀掉

 


 四、AI 自增锁
MySQL 的自增存在一个回溯问题,简单说 MySQL 的自增是不持久化的。当数据库被异常重启 可以通过 select max(auto_inc_col)from t for update;

重新获得表的自增起始id 值,这个可能会造成 id 冲突。

自增锁在提交完成之后就已经被释放了。所以自增锁持有的时间是SQL的执行时间。假如你插入的是一个大事务的话就会出现阻塞了。

而x,ix 等是需要commit 之后才能释放的。

 

设置 innodb_autoinc_lock_mode=2 // 每一条记录加锁释放,这个提高了并发能力,但是可能出现一条语句中的数据不连续了。

 



推荐阅读
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • DAO(Data Access Object)模式是一种用于抽象和封装所有对数据库或其他持久化机制访问的方法,它通过提供一个统一的接口来隐藏底层数据访问的复杂性。 ... [详细]
  • 一个建表一个执行crud操作建表代码importandroid.content.Context;importandroid.database.sqlite.SQLiteDat ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • 本文介绍了如何在 Spring Boot 项目中使用 spring-boot-starter-quartz 组件实现定时任务,并将 cron 表达式存储在数据库中,以便动态调整任务执行频率。 ... [详细]
  • Nacos 0.3 数据持久化详解与实践
    本文详细介绍了如何将 Nacos 0.3 的数据持久化到 MySQL 数据库,并提供了具体的步骤和注意事项。 ... [详细]
  • Docker 环境下 MySQL 双主同步配置指南
    本文介绍了如何在 Docker 环境中配置 MySQL 的双主同步,包括目录结构的创建、配置文件的编写、容器的创建与设置以及最终的验证步骤。 ... [详细]
  • 本文详细介绍了 Spark 中的弹性分布式数据集(RDD)及其常见的操作方法,包括 union、intersection、cartesian、subtract、join、cogroup 等转换操作,以及 count、collect、reduce、take、foreach、first、saveAsTextFile 等行动操作。 ... [详细]
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 本文详细介绍了如何在 Django 项目中使用 Admin 管理后台,包括创建超级用户、启动项目、管理数据模型和修改用户密码等步骤。 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 如何将Python与Excel高效结合:常用操作技巧解析
    本文深入探讨了如何将Python与Excel高效结合,涵盖了一系列实用的操作技巧。文章内容详尽,步骤清晰,注重细节处理,旨在帮助读者掌握Python与Excel之间的无缝对接方法,提升数据处理效率。 ... [详细]
  • PTArchiver工作原理详解与应用分析
    PTArchiver工作原理及其应用分析本文详细解析了PTArchiver的工作机制,探讨了其在数据归档和管理中的应用。PTArchiver通过高效的压缩算法和灵活的存储策略,实现了对大规模数据的高效管理和长期保存。文章还介绍了其在企业级数据备份、历史数据迁移等场景中的实际应用案例,为用户提供了实用的操作建议和技术支持。 ... [详细]
author-avatar
mobiledu2502894591
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有