高性能mysql笔记总结—chapter01

数据库的逻辑架构

mysql是客户端和服务端的架构,一个客户端占有一个客户端进程的线程连接,线程是会被客户端缓存起来的。

第一层是处理认证和连接

第二层用来解析和优化查询

第三层是用来存储引擎层

特点是存储引擎是可插拔的,也就是说可以替换的

并发问题

加表级别锁或者行级别的锁,表级别的锁是服务端就支持的,而行级别的锁是存储引擎层支持的。

读写锁的机制,读锁是可重复读,写锁是排它锁。

事务

acid,原子性,一致性,隔离性,持久性四个特性

事务的隔离级别

不可重复读,读以提交,可重复读,串行读

事务日志

先修改内存中的值,然后将事务的执行语句顺序写到磁盘,顺序写比较快,然后再另外写入到磁盘中,这种方式叫write ahead logging

mvcc

多版本事务控制,是通过保存快照来实现的。是指每一行都会多两个字段,分别表示行的创建时间和删除时间,实际上,就是行级别锁的一种实现方式。

mysql的存储引擎

主要其实就两种,分别是innodb和myisam是最常用的,95都是选择的innodb

相关推荐
冬天豆腐4 分钟前
Springcloud,Nacos管理,打jar包后,启动报错
java·spring cloud·maven·jar
今儿敲了吗21 分钟前
44| 汉诺塔问题
数据结构·c++·笔记·学习·算法·深度优先
redgxp21 分钟前
SpringBoot3整合FastJSON2如何配置configureMessageConverters
java
空空kkk25 分钟前
Java集合——List
java
telllong25 分钟前
C++20 Modules:从入门到真香
java·前端·c++20
花姐夫Jun34 分钟前
WebGL学习-czm_getMaterial详解
学习·webgl
野犬寒鸦35 分钟前
从零起步学习计算机操作系统:内存管理篇
服务器·后端·学习·缓存·面试
程序员小崔日记35 分钟前
一道基础计算题卡在 40 分,求助判题规则问题
java·算法·竞赛
是Yu欸36 分钟前
LangGraph 智能体状态管理与决策
java·javascript·数据库
计算机学姐36 分钟前
基于SpringBoot的中药材店铺管理系统
java·vue.js·spring boot·后端·spring·tomcat·推荐算法