Java基础

MySQL详解1.概论

2019-01-15  本文已影响0人  卢卡斯哔哔哔

点击进入我的博客

1 逻辑架构

MySQL逻辑架构图
连接管理

每个客户端连接都会在服务器进程中拥有一个线程,这个连接的查询只会在这个单独的线程中执行,该线程只能轮流在某个CPU核心或者CPU中运行。服务器会负责缓存线程,因此不需要为每一个新建的连接创建或者销毁线程。

2 锁

读写锁

读锁:读锁是共享的(共享锁),多个线程在同一时刻可以同时读取一个资源;
写锁:写锁是排他的(排他锁),一个写锁会阻碍其他线程的读和写。

锁策略

一方面,锁力度越精细并发能力越强,尽量只锁定需要修改的部分数据,而不是全部的资源;
另一方面,锁的各种操作(获得锁、检查锁、释放锁等)都会增加系统开销,影响系统性能。
锁策略就是在锁的开销和数据的安全性之间寻求一定的平衡,达到最高的并发能力。

表锁

表锁是MySQL最基本的锁策略,也是开销最小的策略,它会锁定整张表。
写锁比读锁有更高的优先级,一个写锁请求可能会被插入到读锁队列的前面。

行级锁

行级锁可以最大成都的支持并发处理,同时开销也是最大的。
InnoDB以及其他存储引擎实现了行级锁。
行级锁只在存储引擎层实现,而MySQL服务器层完全不了解存储引擎中的锁实现。

3 事务

事务就是一组原子性的SQL查询,事务内的语句要么全部执行成功,要么全部执行失败。
可以使用START TRANSACTION开始一个事务,然后要么使用COMMIT提交事务,要么使用ROLLBACK撤销所有修改。

3.1 ACID原则

3.2 隔离级别

隔离级别
设置隔离级别

可以通过SET TRANSACTION ISOLATION LEVEL命令来设置隔离级别。新的隔离级别会在下一个事务开始的时候生效。可以在配置文件中设置整个数据库的隔离级别,也可以只改变当前会话的隔离级别:SET TRANSACTION ISOLATION LEVEL READ COMMITTED;。MySQL能够识别所有的4个ANSI隔离级别, InnoDB引擎也支持所有的隔离级别。

3.3 不可重复读与幻读

脏读

指的是事务可以读取未提交的数据。

不可重复读

在一个事务中,两次查询的结果不一致,针对的是update操作。如下所示,(1)和(2)读到的值不一样。

事务A 事务B
START TRANSACTION;
(1)select salary from T_Users where username = 'lucas';
START TRANSACTION;
update T_Users set salary = 1000 where username = 'lucas';
COMMIT;
(2)select salary from T_Users where username = 'lucas';
COMMIT;
幻读

指的是当某个事务在读取某个范围内的记录时,另外一个事务又在该范围内插入或删除了记录,当之前的事务再次读取该范围的记录时,会产生幻行(Phantom Row),针对的是insert和delete。如下所示,(1)和(2)处读取的记录行数不一样。

事务A 事务B
START TRANSACTION;
(1)select * from T_Users where age between 10 and 20;
START TRANSACTION;
insert into T_Users (age) values (15);
COMMIT;
(2)select * from T_Users where age between 10 and 20;
COMMIT;

3.4 死锁

3.5 事务日志

3.6 MySQL的事务

MySQL提供了两种事务型的存储引擎:InnoDB和NDB Cluster。MyISAM是非事务的。

自动提交(AUTOCOMMIT)
# 查看AUTOCOMMIT的值
SHOW VARIABLES LIKE 'AUTOCOMMIT';
# 设置AUTOCOMMIT的值,1或者ON表示启用,0或者OFF表示禁用。
SET AUTOCOMMIT = 0;
事务中混合使用存储引擎
隐式和显示锁定
LOCK TABLES和UNLOCK TABLES

MySQL也支持LOCK TABLES和UNLOCK TABLES语句,这是在服务器层实现的,和存储引擎无关。它们有自己的用途,但并不能替代事务处理。如果应用需要用到事务,还是应该选择事务型存储引擎。

LOCK TABLES和事务之间相互影响的话,情况会变得非常复杂。因此除了事务中禁用了AUTOCOMMIT,可以使用LOCK TABLES之外,其他任何时候都不要显式地执行LOCK TABLES,不管使用的是什么存储引擎。

4 多版本并发控制

什么是多版本并发控制
InnoDB的MVCC

5 InnoDB概览

上一篇 下一篇

猜你喜欢

热点阅读