12.24-12.28Mysql锁阅读笔记
1.Mysql的锁有哪些种类
- 全局锁,
通过flush tables with read lock
应用场景是全局备份,备份的时候如果有两个表,备份
先备份了用户表,然后用户了商品,再备份商品表
那么商品表库存减少了,然而用户表的育儿没有减少
但是再可重复读的事务隔离级别可以用mVCC快照机制解决 - 表级锁
-
表锁
当一个事务锁上表锁之后,它就只能访问自己锁上这个锁的表 -
元数据锁
就是锁上表的元数据,出现一个问题就是,当出现长事务的时候,这个时候,他先select了,这个时候获取的是元数据的读锁,然后当另一个事务修改这个元数据的时候,那么就会获得元数据写锁,但是还未获取,会阻塞,申请元数据锁的事务会形成一个队列,所以后续申请元数据读锁(也就是一个select语句都会阻塞) -
意向锁
意向锁是一个表锁,用作于这个快速检查表中是否有这个行级别锁,也就是说,当我进行加入共享锁或者是独占锁的时候对行,我就会对表加入一个意向独占锁,或者是意向共享锁,这样在后续增加表锁的时候就会冲突,不需要遍历所有的表,就可以进行找到数据库的锁情况。然后意向锁和意向锁之间是不会冲突的,所以行级锁还是按照之前的规矩增加 -
auto_inc锁
用于这个自增数据加锁,目的就是为了确保自增锁的id唯一,不存在这个并发问题。一般来说inc锁是事务级别的,也就是事务提交之后才会对自增锁释放,
auto_inc锁不是事务级别的而是语句级别的,当插入语句结束之后就释放锁,然后在新的版本中auto_inc锁更加轻量化了,变成了只要对字段赋值之后就会释放锁
问题:对于insert selcect语句来说,如果加入的是轻量级的说,那么并发事务的事务就会出现问题,然后备份binlog的时候会只会备份语句,在进行同步的时候,会顺序执行,这样就会出现主从数据不一致的情况,所以我们这种情况可以设置binlog的format格式就是row的形式
- 行级锁
- record记录锁
通过select * form table where xxx for update
然后之后就是分为共享锁和独占锁,共享锁和共享锁可以共存,但是共享锁和独占锁不能够并存,独占锁和独占锁也不能共存 - gap锁
gap可以用来避免幻读,gap锁可以共存 - next-key锁
就是一个gap锁加上一个记录锁 - 插入意向锁
当某个事务要对某个点插入的时候,就会出现一个什么情况呢
如果这个时候有gap锁的时候,就会生成插入意向锁进行等待,然后另外同样插入的时候增加到一个插入意向锁,然而因为唯一性约束,第二个插入就不会成功
Mysql锁的具体锁插入过程
- 哪些sql语句会加锁
updata语句和 delete语句会加上X锁,以及select 方法for update会加X锁 - 什么时候mysql会加入锁
首先是select * xxx for update的时候,不是mysql的快照读而是当前读,这个时候会加锁进行读取
加锁的全部的单位都是next_key锁,然后这个锁的目的主要是防止幻读的,所以当有些时候,不需要加锁也可以避免幻读的话,那么这个锁会退化
首先是分类
唯一索引等值查询,查到了,只会加一个记录锁;没查到,那么就加间隙锁
唯一索引范围查询,
小于, 就加上间隙锁加上之前左右的,记录锁以及间隙锁
小于等于,如果查到了,就加上这个值得记录锁,没查到就仍然是这个间隙锁
大于,就是间隙锁加上右边所有的记录锁和间隙锁
大于等于就是查到了就加上这个得记录锁,没查到就是只有当前间隙锁和后面所有间隙锁和记录锁
非唯一索引等值查询
首先是查到了,就会锁当前主键记录说,同时,会根据锁住前后的间隙锁,这个时候就看前后有没有间隙锁来决定能不能插入与该值相等的
然后是没查到,就会加一个间隙锁
非唯一索引范围查询
小于, 就会加上间隙锁,以及左边所有的记录锁以及间隙锁
小于等于,如果查到会加上该值的记录锁,该值后面的间隙锁,以及该值前面所有的记录锁以及间隙锁 如果没有等于的值,也是加上间隙锁以及左边所有数据的记录锁以及间隙锁
大于 就会加上间隙锁,以及右边所有记录的记录锁以及间隙锁
大于等于,也是查到了就记录锁,该记录左边一个间隙锁,当前记录锁,以及后面所有的记录锁以及间隙锁
没查到就是一个间隙锁,以及后面所有的间隙锁以及记录锁
没有索引的情况
就是会扫描全表,对全表锁起来,所以进行update操作的时候一定要加上索引,要不然一个update就会把所有的数据加上锁
- 什么时候会造成死锁
比如第一个select 等值查询 某一个值
然后他没查到就会将间隙锁锁起来
然后同时第二个selcect也查同样差不多范围的值的时候,也会有一个间隙锁
当第一个事务第二条语句是要插入到该间隙里面的时候,
相关文章:
12.24-12.28Mysql锁阅读笔记
1.Mysql的锁有哪些种类 全局锁, 通过flush tables with read lock 应用场景是全局备份,备份的时候如果有两个表,备份 先备份了用户表,然后用户了商品,再备份商品表 那么商品表库存减少了,然而用户表的育儿…...
支持最新 mysql9的workbench8.0.39 中文汉化教程来了
之前在 B 站上发布了 mysql8 workbench 汉化教程,一年多来帮助很多初学者解决了不熟悉英文的烦恼。 汉化视频可以访问: 2024最新版mysql8.0.39中文版mysql workbench汉化 中文升级 旧版汉化报错解决_哔哩哔哩_bilibili MySql Workbench汉化_哔哩哔哩_…...
golang连接jenkins构建build
1.安装jenkins依赖 go get github.com/bndr/gojenkins2.代码 import ("context""file/utils/logs""github.com/bndr/gojenkins""github.com/gin-gonic/gin""net/http""time" )// 接收单个静态文件上线参数 type…...
SCAU高程进阶题(自用)
18711 字符串去重 Description 一个完全由小写字母组成的长度为n的字符串,现在要求你去除所有重复的字母,并将剩下的字母按从小到大的次序输出。 如输入baaadccaab,输出abcd。 输入格式 第一行一个整数n,表示字符串长度(0<n&…...
基于STM32F103控制L298N驱动两相四线步进电机
文章目录 前言一、模块参数二、接口说明三、准备工作四、直流电机驱动引脚接线效果展示 五、两相四线步进电机驱动步进电机相关概念拍数驱动时序引脚接线效果展示 六、参考示例 前言 L298N 是一种常见的双 H 桥电机驱动模块,广泛用于驱动直流电机和步进电机。它基于…...
libreoffice在Windows和Linux环境的安装和结合Springboot使用教程
前言: 在公司做开发时,遇到一个需求,要求上传的文件有图片,也有word和pdf。预览信息时,既要求能水印展示出来,又要求能大图水印预览。思索许久,我决定采取全部打水印然后转成图片Base64&#x…...
前端开发 -- 自动回复机器人【附完整源码】
一:效果展示 本项目实现了一个简单的网页聊天界面,用户可以在输入框中输入消息,并点击发送按钮或按下回车键来发送消息。机器人会根据用户发送的消息内容,通过关键字匹配来生成自动回复。 二:源代码分享 <!DOCTYP…...
vue+echarts实现疫情折线图
效果: 代码: <<template><div><div id"left1" style "height:800px;width:100%"></div></div> </template><script> //疫情数据//export default {data() {return {data:{//疫情数据…...
服务器nfs文件共享
1. 配置 NFS 服务器(NFS Server) 在 Ubuntu/Debian 上: sudo apt update sudo apt install nfs-kernel-server在 CentOS/RHEL 上: sudo yum install nfs-utils1.2 创建共享目录 选择一个要共享的目录,并确保该目录的权限正确设置。例如,假设我们要共享 /srv/nfs 目录…...
基于Vue+SSM+SpringCloudAlibaba的科目课程管理系统
功能1:科目列表 功能2:条件查询 功能3:分页查询 功能4:excel批量导入 功能5:修改 功能6:删除...
vue3配置caddy作为静态服务器,在浏览器地址栏刷新出现404
vue3配置caddy作为静态服务器,在浏览器地址栏刷新出现404 1 情况描述2 原因3 配置 1 情况描述 在vue打包之后,形成dist文件,采用caddy作为静态资源服务器。在浏览器中输入域名时可以访问网站,但是,进过路由导航栏内部…...
深入理解委托:C# 编程中的强大工具
在面向对象编程中,委托(Delegate) 是一个非常强大且灵活的概念,特别是在 C# 编程语言中。它不仅仅是函数指针的替代品,还提供了更高层次的抽象,使得代码更加简洁、灵活和可维护。在这篇博客中,我…...
【Java 数据结构】合并两个有序链表
🔥博客主页🔥:【 坊钰_CSDN博客 】 欢迎各位点赞👍评论✍收藏⭐ 目录 1. 题目 2. 解析 3. 代码实现 4. 小结 1. 题目 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示…...
基于微信小程序的校园访客登记系统
基于微信小程序的校园访客登记系统 功能列表 用户端功能 注册与登录 :支持用户通过手机号短信验证码注册和登录。个人资料管理 :允许用户编辑和更新个人信息及其密码。站内信消息通知:通知公告。来访预约:提交来访预约支持车牌…...
uniapp 判断多选、选中取消选中的逻辑处理
一、效果展示 二、代码 1.父组件: :id=“this.id” : 给子组件传递参数【id】 @callParentMethod=“takeIndexFun” :给子组件传递方法,这样可以在子组件直接调用父组件的方法 <view @click="$refs.member.open()"...
php8.0版本更新了哪些内容
PHP 8.0版本是PHP语言的一个重要更新,它引入了许多新特性和改进,旨在提高性能、增强代码的可读性和可维护性。以下是PHP 8.0版本更新的主要内容: 一、性能提升 JIT编译器:PHP 8.0引入了Just-In-Time(JIT)…...
Browser Use:AI智能体自动化操作浏览器的开源工具
Browser Use:AI智能体自动化操作浏览器的开源工具 Browser Use 简介1. 安装所需依赖2. 生成openai密钥3. 编写代码4. 运行代码5. 部署与优化5.1 部署AI代理5.2 优化与扩展总结Browser Use 简介 browser-use是一个Python库,它能够帮助我们将AI代理与浏览器自动化操作结合起来;…...
Android笔记(四十):ViewPager2嵌套RecyclerView滑动冲突进一步解决
背景 ViewPager2内嵌套横向滑动的RecyclerView,会有滑动冲突的情况,引入官方提供的NestedScrollableHost类可以解决冲突问题,但是有一些瑕疵,滑动横向RecyclerView到顶部,按住它不放手继续往左拖再往右拖,这…...
POS系统即销售点系统 文档与数据库设计
POS系统即销售点系统,是一种用于商业交易的软硬件集成系统,主要用于管理销售、库存、客户信息等,以下是其详细介绍: 1. 系统组成 硬件部分 : 收银终端:包括传统的台式收银机、平板电脑、智能手机等设备&a…...
安全合规遇 AI 强援:深度驱动行业发展新引擎 | 倍孜网络CEO聂子尧出席ICT深度观察报告会!
12月24日,2025中国信通院深度观察报告会科技伦理与合规发展分论坛在北京举办。本次分论坛主题为“伦理先行,合规致远”,聚焦互联网广告合规治理、移动终端应用生态治理、短视频平台责任限度等前沿话题进行分享与探讨。工业和信息化部领导&…...
JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...
突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合
强化学习(Reinforcement Learning, RL)是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程,然后使用强化学习的Actor-Critic机制(中文译作“知行互动”机制),逐步迭代求解…...
阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...
【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具
文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...
2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...
莫兰迪高级灰总结计划简约商务通用PPT模版
莫兰迪高级灰总结计划简约商务通用PPT模版,莫兰迪调色板清新简约工作汇报PPT模版,莫兰迪时尚风极简设计PPT模版,大学生毕业论文答辩PPT模版,莫兰迪配色总结计划简约商务通用PPT模版,莫兰迪商务汇报PPT模版,…...
论文阅读:LLM4Drive: A Survey of Large Language Models for Autonomous Driving
地址:LLM4Drive: A Survey of Large Language Models for Autonomous Driving 摘要翻译 自动驾驶技术作为推动交通和城市出行变革的催化剂,正从基于规则的系统向数据驱动策略转变。传统的模块化系统受限于级联模块间的累积误差和缺乏灵活性的预设规则。…...
算术操作符与类型转换:从基础到精通
目录 前言:从基础到实践——探索运算符与类型转换的奥秘 算术操作符超级详解 算术操作符:、-、*、/、% 赋值操作符:和复合赋值 单⽬操作符:、--、、- 前言:从基础到实践——探索运算符与类型转换的奥秘 在先前的文…...
Springboot 高校报修与互助平台小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,高校报修与互助平台小程序被用户普遍使用,为…...
