Mysql的逻辑架构_读写锁_事物

概览

  • 一. MySql的逻辑架构
    • 1. 逻辑架构图
    • 2. 连接管理与安全性
  • 二. 并发控制
    • 1. 读写锁
    • 2. 锁粒度
  • 三. 事务
    • 1. 特性
    • 2. 隔离级别
    • 3. 死锁
    • 4. 事物日志?
    • 5.MySql中的事物

mysql最与众不同的特性:存储引擎架构

架构的设计: 将查询处理(Query Processing)及其他系统任务(Server Task)和数据的存储/提取相分离。

处理和存储分离的设计: 可以在使用时根据性能、特性,以及其他需求来选择数据存储的方式。

一. MySql的逻辑架构

1. 逻辑架构图

在这里插入图片描述
(图片来自高性能MySql第3版)

  • 最上层服务大多数基于网络的客户端/服务器的工具或者服务都有类似的架构。(例如连接处理、授权认证、安全等)
  • 第二层架构: Mysql核心服务功能,包括查询解析、分析、优化、缓存以及所有的内置函数及跨存储引擎的功能实现存储过程、触发器、视图等。
  • 第三层架构: 包含了存储引擎。存储引擎负责MySQL中数据的存储和提取。
    服务器通过API与存储引擎进行通信。这些接口屏蔽了不同存储引擎之间的差异,使得这些差异对上层的查询过程透明。
    不同存储引擎之间也不会相互通信,只是简单地响应上层服务器的请求。

2. 连接管理与安全性

在这里插入图片描述

二. 并发控制

1. 读写锁

出现背景: 两个及以上进程在同一时刻对同一资源进行操作,例如读写、写写、写读会出现的数据不一致的并发问题。

概览
在这里插入图片描述

2. 锁粒度

一种提高共享资源并发性的方式就是让锁定对象更有选择性。尽量只锁定需要修改的部分数据,而不是所有的资源。

理想状态下: 只对会修改的数据片进行精确的锁定。
任何时候,在给定的资源上,锁定的数据量越少,则系统的并发程度越高,只要相互之间不发生冲突即可

锁策略: 在锁的开销和数据的安全性之间寻求平衡,因为锁的各种操作会增加系统开销。
在这里插入图片描述

三. 事务

事务就是一组原子性的SQL查询,或者说一个独立的工作单元。

事务内的语句,要么全部执行成功,要么全部执行失败。

1. 特性

在这里插入图片描述

  • 一个实现了ACID的数据库,相比没有实现ACID的数据库,通常会需要更强的CPU处理能力、更大的内存和更多的磁盘空间
  • 用户可以根据业务是否需要事务处理,来选择合适的存储引擎
  • 不需要事务的查询类应用,选择一个非事务型的存储引擎获得更高的性能,即使不存储引擎支持事物,也可以通过LOCK TABLES语句为应用提供一定程度的保护

2. 隔离级别

每一种级别都规定了一个事务中所做的修改,哪些在事务内和事务间是可见的,哪些是不可见的。

较低级别的隔离通常可以执行更高的并发,系统的开销也更低。

概览总结
在这里插入图片描述
在这里插入图片描述

3. 死锁

对于事务型的系统,死锁无法避免的。

死锁发生以后,只有部分或者完全回滚其中一个事务,才能打破死锁。即大多数情况下只需要重新执行因死锁回滚的事务即可。

在这里插入图片描述

4. 事物日志?

在这里插入图片描述
遗留问题: 系统崩溃后恢复的是日志记录数据?

5.MySql中的事物

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

另外还有一些知名的第三方存储引擎也支持事务,包括XtraDB和PBXT。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/8686.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Matlab隐藏彩蛋

Matlab中的彩蛋实现与Matlab的版本有着重要关系,像Android一样,不同的版本对应不同的彩蛋。这里以Matlab 2016A为例。 1.最著名的一个,命令行窗口输入“image”,就会出现一张倒置的小孩脸,不知情的使用者很可能会被吓…

DS-font

paper:https://arxiv.org/pdf/2301.10008.pdf title: Few-shot Font Generation by Learning Style Difference and Similarity accepted: arXiv 2023 abstract 少镜头字体生成(FFG)旨在保留原始字符的底层全局结构,同时通过参考一些样本生成目标字体。它已应用于字体库创…

(1)ADS-B接收机

文章目录 前言 1.1 所需硬件 1.2 连接到自动驾驶仪 1.3 设置 1.4 ADSB输出配置 1.5 启用载人飞行器避障功能 1.6 飞行器数据库 1.7 开发者信息包括模拟 前言 本文介绍了如何安装和配置 ADS-B 模块,以便你的飞机能够知道附近的其他飞机和空中交通管制&#x…

FPGA纯verilog实现UDP协议栈 AXIS用户接口,可替代Tri Mode Ethernet MAC,提供三套工程源码和技术支持

目录 1、前言2、我这里已有的UDP方案3、该UDP协议栈性能4、详细设计方案网络PHYRGMII转GMII模块AXIS FIFOUDP协议栈 5、vivado工程1-->B50610 工程6、vivado工程1-->RTL8211 工程7、vivado工程1-->88E1518 工程8、上板调试验证并演示准备工作查看ARPUDP数据回环测试 9…

【计算机视觉】DETR 系列的最新综述!

论文地址: https://arxiv.org/pdf/2306.04670.pdf项目地址: https://github.com/mindgarage-shan/trans_object_detection_surveyTransformer在自然语言处理(NLP)中的惊人表现,让研究人员很兴奋地探索它们在计算机视觉任务中的应用。与其他…

Spring Boot 中的 RabbitMQ 的消息接收配置是什么,原理,如何使用

Spring Boot 中的 RabbitMQ 的消息接收配置是什么,原理,如何使用 RabbitMQ 是一个流行的消息队列系统,它可以用于在应用程序之间传递消息。Spring Boot 提供了对 RabbitMQ 的支持,我们可以使用 Spring Boot 中的 RabbitMQ 消息接…

前端学习——jsDay2

运算符 赋值运算符 一元运算符 比较运算符 逻辑运算符 小练习 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name…

Selenium基础 — Selenium自动化测试框架介绍

1、什么是selenium Selenium是一个用于Web应用程序测试的工具。只要在测试用例中把预期的用户行为与结果都描述出来&#xff0c;我们就得到了一个可以自动化运行的功能测试套件。Selenium测试套件直接运行在浏览器中&#xff0c;就像真正的用户在操作浏览器一样。Selenium也是…

物联网工控屏在ROV布放回收系统中的应用

一、背景 1. 深海作业装备制造行业 随着我国经济与科学技术的发展壮大&#xff0c;作为“蓝色粮仓”的海洋能源开采建设逐渐成为一项重要的事业。深海作业装备则成为海洋能源开采的必备和关键工具&#xff0c;其性能和可靠性须得以保障。也因此&#xff0c;开发性能表现更优、…

【MySQL】数据库SQL语句之DML

目录 前言&#xff1a; 一.DML添加数据 1.1给指定字段添加数据 1.2给全部字段添加数据 1.3批量添加数据 二.DML修改数据 三.DML删除数据 四.结尾 前言&#xff1a; 时隔一周&#xff0c;啊苏今天来更新啦&#xff0c;简单说说这周在做些什么吧&#xff0c;上课、看书、…

CSDN及其他的快捷键--更新中--

目录 一、CSDN的快捷键 二、Windows电脑常用的快捷键 三、IDEA常用快捷键&#xff1a; 一、CSDN的快捷键 ctrl1&#xff1a;光标所在行标识为标题1&#xff0c;ctrl2则为标题2&#xff0c;ctrl3则为标题3……使用列表后&#xff0c;按一次回车键就往前进一层&#xff0c;…

thinkphp6使用think-queue实现普通队列和延迟队列

Redis的延迟队列可以用于以下场景&#xff1a; 需求说明&#xff1a; 当用户申请售后&#xff0c;商家未在n小时内处理&#xff0c;系统自动进行退款。 商家拒绝后&#xff0c;用户可申请客服介入&#xff0c;客服x天内超时未处理&#xff0c;系统自动退款。 用户收到货物&…