IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL优化学习日记10——锁机制 -> 正文阅读

[大数据]MySQL优化学习日记10——锁机制

目录

一、锁机制

1.1 作用

1.2 解决

1.3 分类

二、表锁

2.1 新建表并添加数据

2.2 查看加锁情况

2.3 会话(session):

2.4 加读锁:

2.5 释放锁

2.6 加写锁

2.7 MySQL 表级锁的锁模式

2.8 分析表锁定

三、行锁

3.1?新建表并添加数据

3.2 commit

3.3 测试

3.4 对于行锁:?

3.5?行锁的注意事项


一、锁机制

1.1 作用

解决因资源共享而造成的并发问题

示例:买最后一件衣服

A、B 都能看到这一件衣服 A 抢先买了。系统没有及时更新,导致 B 也买了一个。

1.2 解决

信号量机制,A 在操作的时候是被加上锁了,B不能进行操作。

1.3 分类

1、按照操作类型分类

(1) 读锁(共享锁):对同一个数据(衣服),多个读操作可以同时进行,互不干扰。

(2) 写锁(互斥锁):如果当前写操作没有完毕(买衣服的一系列操作),则无法进行其他的读锁、写锁

2、按照操作访问分类

(1) 表锁:一次性对一张表整体加锁。如 MyISAM 存储引擎使用表锁,开销小、加锁快,无死锁。但锁的范围大,容易发生锁冲突、并发度低。

(2) 行锁:一次性对一条数据加锁。如 InnoDB 存储引擎使用行锁,开销大,加锁慢,容易出现死锁,锁的范围较小,不易发生锁冲突,并发度高(很小概率发生高并问题:脏读、幻读、不可重复读、丢失更新等问题)

(3) 页锁

二、表锁

2.1 新建表并添加数据

create table tablelock
(
    id int primary key auto_increment,
    name varchar(20)
) engine myisam;


insert into tablelock(name) values('a1');
insert into tablelock(name) values('a2');
insert into tablelock(name) values('a3');
insert into tablelock(name) values('a4');
insert into tablelock(name) values('a5');

2.2 查看加锁情况

show open tables;

2.3 会话(session):

每一个访问数据的dos命令行、数据库客户端工具库等都是一个会话

2.4 加读锁:

????????会话 0:lock table tablelock read;

?????????会话 0:select * from tablelock;? ?——读(查),可以

? ? ? ? ?会话0:delete from tablelock where id =1;???——写(增删改),不可以

?????????会话1:select * from tablelock;? ?——读(查),可以

?????????会话1:delete from tablelock where id =1;???——写(增删改),会“等待”会话 0 将锁释放

总结:

会话 0 给 A 表加了锁,其他会话的操作:

(1) 可以对其他表(A表以外的表)进行读、写操作

(2) 对 A 表:可以读,写需要等待

2.5 释放锁

unlock tables;

2.6 加写锁

????????会话 0:lock table tablelock write;

? ? ? ? 当前会话(会话0)可以对加了写锁的表进行任何操作(增删改查);但是不能操作(增加改查)其他表

? ? ? ? ?其他会话:

? ? ? ? 对会话 0 中加写锁的表 可以进行增删改查的前提是:等待会话 0 释放写锁

?

2.7 MySQL 表级锁的锁模式

MyISAM 在执行查询语句(SELECT)前,会自动给涉及的所有表加读锁,在执行更新操作(DML)?前,会自动给涉及的表加写锁。所以对 MyISAM 表进行操作,会有以下情况:

a、对 MyISAM 表的读操作(加读锁),不会阻塞其他进程(会话)对同一表的读请求,但会阻塞对同一表的写请求。只有当读锁释放后,才会执行其它进程的写操作。

b、对 MyISAM 表的写操作(加写锁),会阻塞其他进程(会话)对同一表的读和写操作,只有当写锁释放后,才会执行其它进程的读写操作。

2.8 分析表锁定

查看哪些表加了锁:show open tables;? —— 1代表被加了锁

分析表锁定的严重程度:

show status like 'Table%';

Table_locks_immediate :即可能获取到的锁

Table_ locks_ wai ted:需要等待的表锁数(A 上锁, B 在 A 之后上锁,C 访问表要等两个锁)(如果该值越大,说明存在越大的锁竞争)

一般建议:Table_locks_immediate / Table_ locks_ wai ted > 500,采用 InnoDB 引擎,否则使用 MyISAM 引擎

三、行锁

3.1?新建表并添加数据

create table linelock
(
id int(5) primary key auto_increment,
name varchar(20)
)engine=innodb;

insert into linelock(name) values('1');
insert into linelock(name) values('2');
insert into linelock(name) values('3');
insert into linelock(name) values('4');
insert into linelock(name) values('5');

3.2 commit

mysql 默认自动 commit;oracle 默认不会自动 commit;

为了研究行锁,暂时将自动 commit 关闭 —— set autocommit=0;? 后面需要 commit 提交

3.3 测试

? ? ? ? ?会话0:写操作 insert into linelock values(6, 'a6');

?????????会话1:写操作 update linelock set name='ax' where id=6;

????????会话0:t提交操作 commit;? ?会话0已经请求超时了。

3.4 对于行锁:?

1、如果会话 x 对某条数据 a 进行 DML 操作(研究时关闭了自动 commit),其他会话需要等待会话 x 结束事务(commit / rollback)后 才能对数据 a 进行操作。

2、表锁是通过 unlock tables; 结束事务? 行锁是通过?commit/rollback 事务提交结束事务

3.5?行锁的注意事项

1、如果没有索引,则行锁会转为表锁

show index from linelock;

新加一个索引?alter table linelock add index idx_linelock_name(name);

?

?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:21:05  更:2022-03-03 16:25:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 20:59:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码