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

news2025/1/10 3:39:07

概览

  • 一. 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.coloradmin.cn/o/707326.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

7、注解与自定义注解

1 注解 注解很厉害,它可以增强我们的java代码,同时利用反射技术可以扩充实现很多功能。它们被广泛应用于三大框架底层。 传统我们通过xml文本文件声明方式(如下图,但是XML比较繁琐且不易检查),而现在最主流的开发都是基于注解方式&#xff0c…

房贷计算器——新增选择还款方式

房贷计算器——新增选择还款方式 #!/usr/bin/env python # coding: utf-8# In[4]: 文字‘房贷计算器’ 文字‘贷款总金额’:输入框 文字‘贷款期限’:输入框 文字‘年利率’:输入框 按钮‘开始计算’ 返回: 月供 总利息 from tki…

【Framework】bindService启动流程

前言 在【Service启动流程之startService】 中,我们已经分析了startService的流程,这篇就继续讲bindService的流程,他们两有很多相似之处。同样,流程图在总结处。 我们在调用bindService方法时候,实际调用的是Contex…

台庆|三联开关怎么接线?

三联开关是一种常见的开关类型,通常用于控制一个电路中的三个不同的电器或灯具。它的用途非常广泛,因此了解如何正确接线是非常重要的。在本文中,我们将详细讨论三联开关的接线方法。 我们先来看看三联开关实物图与线路图: 接下来…

【音视频处理】FFmpeg详解,命令行、源码、编译安装

大家好,欢迎来到停止重构的频道。 本期我们讨论FFmpeg。 这里先提一个问题,FFmpeg命令行功能如此强大,为什么还需要舍近求远地调用库函数呢 ? 我们按这样的顺序讨论 : 1、 FFmpeg命令行说明 2、 FFmpeg代码结构…

如何在 JavaScript 中压缩字符串

在 JavaScript 中,可以有范围很广的压缩,比如 gzip 之类的文件压缩等等。 在这里,我们将讨论两种压缩字符串的方法。 最初,我们将重点介绍霍夫曼算法。 稍后,我们将介绍解决任务的 LZString 方法。 在 JavaScript 中使…

主成分分析系列(一)概览及数据为何要中心化

一、概览 主成分分析(Principle Component Analysis,PCA)算法属于数据降维算法里面的一种。数据降维算法的主要想法是从高维度数据中找到一种结构,这种结构蕴含了数据中的大部分信息,从而将高维数据降维到低维数据&am…

Apikit 自学日记:参数构造器

构造器是测试时系统提供的快速生成请求数据的工具。一般用于快速对数据进行加密和生成随机数值。可在请求参数中某个字段的右侧选择构造器操作,通过构造器生成该字段的参数值。构造器由两种类型的操作组成:设置初始数据和多重操作。 设置初始数据 其中初…

基于C语言的开源csv解析库:MiniCSV使用示例

文章目录 MiniCSV简介官方示例csv文件解析示例CodeBlocks工程下载 MiniCSV简介 之前写了一篇基于C语言字符串操作函数的csv文件解析:C语言解析csv格式文件,本文介绍一个开源简洁的csv解析库的使用:MiniCSV,使用标准C语言设计。 …

Spring Boot 中的 Redis 的数据操作配置和使用

Spring Boot 中的 Redis 的数据操作配置和使用 Redis 是一种高性能的 NoSQL 数据库,它支持多种数据结构,包括字符串、哈希、列表、集合和有序集合。Redis 还提供了丰富的命令,可以对数据进行快速的 CRUD 操作。Spring Boot 是一个基于 Sprin…

数据结构--栈的引用--前中后缀表达式(前部分)

数据结构–栈的引用–前中后缀表达式(前部分) 常见的算数表达式 由三个部分组成: 操作数、运算符、界限符 \color{red}操作数、运算符、界限符 操作数、运算符、界限符 ps:界限符是必不可少的,反映了计算的先后顺序 波兰表达式(让计算机更容易识别的算数表达式) Reverse Po…

高性能分布式缓存Redis(一) 快速实战

一、缓存发展史&缓存分类 1.1、大型网站中缓存的使用 访问量越大,响应力越差,用户体验越差。 引入缓存、示意图如下: 读写策略: Cache Aside Pattern(旁路缓存模式)Read/Write Through Pattern&am…

AA-TransUNet github: 用于预测任务的注意力增强的TransUNet

文章目录 来源AA_TransUNet架构数据集和预训练模型使用作者 来源 github地址 AA_TransUNet架构 数据集和预训练模型 如果你对本文中使用的数据集(降水图和云量数据集)感兴趣,请访问SmaAt-UNet了解更多细节。 对于预训练的AA_TransUNet模型…

从磁盘看 IO

计算机上的易失和非易失存储器 常见磁盘可以分为两类:机械磁盘和固态磁盘。 第一类,机械磁盘,也称为硬盘驱动器(Hard Disk Driver),通常缩写为 HDD。机械磁 盘主要由盘片和读写磁头组成,数据就…

认识固态继电器及其工作原理

什么是固态继电器,有什么优缺点? 固态继电器 简称SSR,又被称之为“无触点开关”它利用电子元件(如双向可控硅等半导体器件)的开关特性,可到达无触点无火花地接通和断开电路。 固态继电器工作可靠&#…

1.3 Metasploit 生成SSL加密载荷

在本节中,我们将介绍如何通过使用Metasploit生成加密载荷,以隐藏网络特征。前一章节我们已经通过Metasploit生成了一段明文的ShellCode,但明文的网络传输存在安全隐患,因此本节将介绍如何通过生成SSL证书来加密ShellCode&#xff…

ChatGPT应用工具推荐

ChatGPT作为一种先进的自然生成技术,已经在各个领域展现出了其强大的应用能力,下面将给大家介绍一些ChatGPT的功能应用。 简介 此系统是基于likeadmin—PHP开发的智能对话系统,ChatGPT是一种基于人工智能技术的聊天机器人,它可以…

如何利用AI智能聊天机器人 10秒钟做出一个故事绘本的神奇插件

原文链接:如何利用AI智能聊天机器人10秒钟做出一个故事绘本的神奇插件 C_h~at_&G&&P_T : 以下称为AI智能聊天机器人 一、AI智能聊天机器人4中集成“Stories”插件 对于已经熟悉使用AI智能聊天机器人4 的插件的朋友们,直接在应用市场里搜索…

vtkdicom0.8_vtk9.2_dcmtk3.6.7_qt6.2编译OK

目录 0 结果展示 1 cmake要点 2 编译报错解决 3 参考链接 0 结果展示 1 cmake要点 注意DCMTK_dcmtk_INCLUDE_DIR 2 编译报错解决 D:\Work\C\qt6Work\DCMTK\install\bin\dcmtkcharls.dll : fatal error LNK1107: 文件无效或损坏: 无法在 0x308 处读取 修改,从…

docker安装mysql并且进行连接

1、拉取镜像、在linux中执行命令 docker pull mysql 2、运行容器、在linux中执行命令 docker run -d --name mysql -p 3308:3306 -e MYSQL_ROOT_PASSWORD123456 mysql3、 进入容器、在linux中执行命令 docker ps -a docker exec -it 2a85f05d4090 /bin/bash 4、登录docker中的m…