| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> 5.mysql的锁 -> 正文阅读 |
|
[大数据]5.mysql的锁 |
锁的分类按照锁的类型来分:
按照锁的粒度来分:
操作锁的语句查看是否有锁
加锁语句,book表上一个写锁,mylock表上读锁
解锁(全部解锁)
表锁场景现在有两张表mylock和book,两个会话1和2,会话1在mylock上加了一把读锁会导致的事:
另起一个场景,会话1现在在mylock表上加的是写锁:
总结起来就是读锁不会阻塞其他进程对同一表的读请求,但是会阻塞写请求,写锁会阻塞其他进程的读和写请求,并且在一个锁没有解开之前,该进程不允许操作其他的表 分析表锁状态 通过两个变量table_locks_waited和table_locks_immediate,通过命令show status like 'table%'就可以查看
MyISAM的读写锁调度是写优先,这也是MyISAM不适合做写为主表的引擎,因为写锁后,其他线程不能做任何操作,大量的更新会导致很难拿到锁,造成长久阻塞.InnoDB和MyISAM最大的不同有两点:一是InnoDB支持事务,二是它采用了行级锁 行锁场景行锁需要回顾的问题:acid?事务的隔离级别?脏读?不可重复读?幻读? 会话1设置自动提交为false:set autocommit=0,会话1操作表更改了一行数据:
索引失效:索引失效以后,会导致行锁转换为表锁,比如建立了索引的列a,本来是varchar,但是在查询的时候没有加''导致自动类型转换,索引失效,这时行锁就会自动转换成表锁 间隙锁的危害:当我们使用范围条件而不是相当条件检索数据,并且请求共享或者排他锁的时候,InnoDB会给复合条件的已有数据记录的索引项加锁,对于键值在条件范围内但是不存在的记录,我们称之为间隙,InnoDB也会对这个间隙加锁,这就是间隙锁(表的情况为1-9但是没有2,会话1操作大于等于1小于等于9的值,会话2新插入2会导致会话2进入阻塞) 读的时候如何锁定一行: select * from table where a=1 for update,通过for update这个语句就在读的时候也加上了锁 分析行锁状态 ?通过检查InnoDB_row_lock状态变量来不分析系统上行锁的争夺情况.查询语句:show status like 'InnoDB_row_lock' InnoDB_row_lock_current_waits:当前正在等待锁定的数量 InnoDB_row_lock_waits:系统启动后到现在总共等待的次数 InnoDB_row_lock_time_avg:等待的平均时长 InnoDB_row_lock_time:等待的总时长 优化建议
主从复制?步骤分为三步:
基本的原则: 每个slave只有一个master,每个slave只能有一个唯一的服务器ID,每个master可以有多个slave 一主一从常见配置: |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 23:38:06- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |