博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux运维 第四阶段 (四) MySQL锁、事务
阅读量:6504 次
发布时间:2019-06-24

本文共 2210 字,大约阅读时间需要 7 分钟。

1、相关概念:

连接管理器:接受请求、建立安全连接、认证用户等;

线程管理器:线程池,线程重用thread-reuse

解析器:解析树;

缓存:复杂性、算法、权限等;

>SELECT CURRENT_TIME();  (此命令不缓存)

并发控制问题:两个以上用户同时读写同一个文件数据,多版本并发控制MVCC,时间快照;

 

锁(最简单的并发控制机制):读锁(共享锁);写锁(独占锁、排他锁);

>HELP LOCK

>LOCK TABLES  tb_name  [READ|WRITE];

>UNLOCK;

锁粒度划分:从大到小依次,表锁(锁定整张表)、页锁(数据块,一块有多行)、行锁,mysql只支持表锁,行锁需要由存储引擎完成;锁越粗糙越容易管理,锁越精细越能实现并发性,相对内部越复杂。

注:若同时有多个用户写一张表,锁操作会在mysql内部自动完成,我们不需要加锁;在实现数据库的温备份时才需要加锁操作。

 

2、事务transaction

ACID(Atomicity;Consistency;Isolation;Durability)

Atomicity原子性:事务所引起的DB操作要么都完成,要么都不执行;

Consistency一致性:当事务执行结束之后,整个server状态没有改变,事务前的总和和事务后的总和是一致的(前提在隔离状态下执行),如:银行帐户A(3000)——》B(2000);

Isolation隔离性:事务调度(事务之间影响最小),MVCC(多版本并发控制);

Durability持久性:一旦事务成功完成,系统必须保证任何故障都不会引起事务表现出不一致性。


隔离级别有四种,从低到高依次为:

READ UNCOMMITTED读未提交;

READ COMMITTED读提交;

REPEATABLE READ可重读;(mysql默认)

SERIALIZABLE可串行。


>SHOW GLOBAL  VARIABLES  LIKE  ‘tx_isolation’;

>SELECT @@tx_isolation;  (两种方法查看隔离级别)

>SET GLOBAL|SESSION  tx_isolation=’READ-UNCOMMITTED’;  (修改隔离级别)

注:隔离级别越低,各事务间干扰大,但并发能力强;隔离级别越高,并发能力越弱,但安全性越好。隔离级别调低,可提高性能。

 

增删改查首先在内存中完成,再写到事务日志中,过段时间才同步到数据文件中(磁盘空间),所以在事务引擎上每次写操作都要执行两遍,一次从内存到事务日志中(速度快,仅记录操作过程),一次是事务日志写入数据文件中(持久)。

内存――》事务日志(撤销);事务日志――》磁盘(同步)

保证ACID的兼容性:redo  log(重做日志);undo  log(撤销日志)。

日志组:日志文件至关重要,并不是越大越好,根据事务需求。启动mysql时会同步事务日志到磁盘,不能终止,否则 mysql可能会崩溃。

事务日志尽量拿出来放另一磁盘。

 

>START TRANSACTION;  (启动事务)

>多条SQL语句执行,例:>INSERT  INTO tb_name......;  (事务中的SQL语句是整体,要么都执行,要么都不执行)

>COMMIT;>ROLLBACK;  (事务一旦提交就不能再撤了)

 

>SELECT @@autocommit;  (如没明确启动事务,autocommit能实现自动提交,每一个操作都直接提交,建议明确使用事务>START TRANSACTION;并关闭自动提交,系统性能要高的话,IO操作越少越好)

>SET  GLOBAL  autocommit=0; (关闭自动提交,永久生效可写入配置文件)

 

>HELP SAVEPOINT  (保存点,>SAVEPOINT  sp_name;

>START TRANSACTION;

>DELETE FROM  tutors  WHERE  Age<25;

>SAVEPOINT  ab;  (保存点名称不能使用数字)

>INSERT INTO  tutors  (Tname,Gender,Age)  VALUES (‘jowin’,’M’,25);

>SAVEPOINT  ac;

>ROLLBACK  TO ab;  (回滚至之前的保存点)

>COMMIT;

 

多事务同时执行(彼此之间互相不影响的方式并发,可提高吞吐量和资源利用率,并减少等待时间),事务之间的交互通过数据集。

 

并发控制所依赖的技术手段:锁(饿死-锁饥饿,要锁但申请不到;死锁)、时间戳、多版本控制和快照隔离。

 

事务的状态:活动的;部分提交的;提交的;失败的;中止的。

 

事务调度:可恢复调度;无级联调度。

 

查看事务隔离级别对事务的影响:在两个终端上进行

>SELECT @@tx_isolation;

>SET tx_isolation=’READ-UNCOMMITTED’;  (在一终端上来回切换隔离级别)

>UPDATE tb_name  SET.....;

>ROLLBACK;

>COMMIT;

>SELECT *  FROM  tb_name; (在另一终端查看)

 

 

本文转自 chaijowin 51CTO博客,原文链接:http://blog.51cto.com/jowin/1683317,如需转载请自行联系原作者

你可能感兴趣的文章
Microsoft Dynamics CRM 2013 Reporting Extensions 正式安装
查看>>
Redis 管理命令
查看>>
一种测试方向的探讨-基于模型测试调研引发的思考 - 4
查看>>
EL表达式详解
查看>>
SpringMVC3.1.1+Spring3.1.1+Hibernate4+Velocity+EasyUI+ZTree实现RBAC基于角色的访问控制(二)...
查看>>
Validation Application Block动手实验室
查看>>
SSRS 2012 交互式报表 -- 单层文档结构图
查看>>
企业级监控软件zabbix搭建部署之zabbix server的安装(一)
查看>>
check_nginx pnp4nagios 模版
查看>>
Windows Server 2008 R2之六活动目录域服务的卸载
查看>>
私有网盘nextcloud 12的使用介绍
查看>>
ASP.NET 主题(Themes)FAQ
查看>>
linux命令实践-du
查看>>
什么是双核处理器?双核的概念是什么?
查看>>
文档转换拾遗
查看>>
操作主机 Schema Master[为企业维护windows server 2008系列九]
查看>>
AI产品开发指南:5大核心环节搞定机器学习工作流
查看>>
解决客户一例:使用域超级管理员打开Exchange 2010发现没有权限
查看>>
Maven中解决system的jar依赖,打包复制问题
查看>>
物联网操作系统已现中国时机
查看>>