高性能MySQL实战学习笔记~1

一 MySQL体系结构

1. Client Connectors

  • 处理客户端的连接请求, MySQL支持所有的连接类型

2. MySQL Server

  • 连接处理: 响应客户端连接请求, 线程池资源管理
  • 用户鉴权: 用户登录身份鉴权
  • 安全管理: 用户执行操作权限校验

3.Service & utilities

  • 管理服务&工具集: 备份恢复, 安全管理, 集群管理服务&工具

4.SQL Interface

  • SQL接口: 接收用户的SQL命令并处理

5.Parser

  • SQL解析器: 解析查询语句, 生成语法树, 解析器会查询缓存

6.Optimizer

  • 查询优化器: 对查询语句进行优化, 选择合适索引

7.Caches

  • 缓存: 全局缓存和session缓存

8.Pluggable Storage Engines

  • 存储引擎层: 一种文件访问机制, 与文件交互, 插件式存储引擎

9.File System

  • 物理文件存储层: 物理文件的存储, 含redolog, undolog, binlog, error_log, query_log, slow_log, ibd, frm等

二 SQL的执行流程

1. select

在这里插入图片描述

2. insert

待完善…

三 存储引擎及其分类

1. 存储引擎

  • MySQL中具体与文件打交道的子系统, 根据MySQL公司提供的文件访问层抽象接口定制的一种文件访问机制

2. 分类

  • MyISAM
  • InnoDB
  • Memory
  • NDB
  • Archive
  • Blackhole
  • Merge
  • CSV
  • TokuDB
  • RocksDB
  • MyRocks
  • ArkDB
  • Federated
  • Example
  • PERFORMANCE_SCHEMA
  • MRG_MYISAM

四 InnoDB存储引擎体系结构

1. 实例层

1-1 master thread(优先级最高)

  • 负责调度其他各线程, 内部包含主循环(1s和10s), 后台循环, 刷新循环
  • 主循环的两种操作
    • 1s
      • 第一步: 日志缓冲刷新到磁盘(会总是操作, 即使事务还没有提交)
      • 第二步: 最多可能刷100个新脏页到磁盘
      • 第三步: 执行和并改变缓冲的操作
      • 第四步: 若当前没有用户活动可能切换到后台循环等
    • 10s
      • 第一步: 刷新可能最多100个脏页到磁盘
      • 第二步: 合并至多5个改变缓冲(总是)
      • 第三步: 日志缓冲刷新到磁盘(总是)
      • 第四步: 删除无用的undo页(总是)
      • 第五步: 刷新100个或者10个脏页到磁盘(总是)产生一个检查点(总是)等

1-2 buf dump thread

  • 负责把 buffer pool 中的内容 dump 到物理文件中, 以便快速加热数据

1-3 page cleaner thread

  • 负责把buffer pool中的脏页刷新到磁盘, 5.7版本之后才出现

1-4 purge thread

  • 负责将不再使用的undo日志进行回收

1-5 read thread

  • 处理用户的读请求, 并负责将数据页从磁盘上读出来

1-6 write thread

  • 负责将数据页从缓冲区写出到磁盘

1-7 redo log thread

  • 负责把日志缓冲中的内容刷新到 redo log 文件中

1-8 insert buffer thread

  • 负责把nsert buffer中的内容刷新到磁盘

1-9 Buffer Pool

buffer pool文件决定了一个SQL执行的快慢

单机单实例参考配置: 物理内存的 60% - 80%

多机多实例: 不用超过物理内存的 80%

看 show global status like '%buffer_pool_wait%'的值

(5.7以后版本buffer pool大小可以动态修改, 无需重启数据库实例)

  • undo page(undo页)
  • insert buffer page(insert buffer页)
  • adaptive hash index(自适应hash索引页)
  • index page(索引页)
  • lock info(锁信息)
  • data dictionary(数据字典页)

1-10 redo log buffer

  • 是一个循环复用的文件集件
  • 负责记录InnoDB中所有对Buffer Pool的物理修改日志
  • redo log大小直接影响了我们的数据库的处理能力

1-11 double write buffer

  • 主要解决由于宕机引起物理写入操作中断, 数据页不完整的情况

2. 物理层

2-1 系统表空间

  • 5.6
    • ibdata文件
      • insert buffer
      • double write
      • 回滚
      • 索引
      • 数据字典
      • undo信息
    • undo文件
  • 5.7
    • undo信息(5.7之后从ibdata分离出来)
    • 新增temporary(临时表空间)
  • 8.0
    • 数据字典(8.0之后从ibdata分离出来)
    • temporary可以配置多个物理文件

2-2 用户表空间

  • .ibd后缀的文件
    • insert buffer的bitma页
    • 叶子页
    • 非叶子页

2-3 redo日志

  • 多个redo文件

五 几个主流存储引擎特性

FeatureMyISAMMemoryInnoDBArchiveNDB
B-tree indexesYesYesYesNoNo
Backup/point-in-time recovery (note 1)YesYesYesYesYes
Cluster database supportNoNoNoNoYes
Clustered indexesNoNoYesNoNo
Compressed dataNNoYesYesNo
Data cachesNoN/AYesNoYes
Encrypted dataYes(note 3)Yes(note 3)Yes(note 4)Yes(note 3)Yes(note 3)
Foreign key supportNoNoYesNoYes(note 5)
Full-text search indexesYesNoYes(note 6)NoNo
Geospatial data type supportYesNoYesYesYes
Geospatial indexing supportYesNoYes(note 7)NoNo
Hash indexesNoYesNo(note 8)NoYes
Index cachesYesN/AYesNoYes
Locking granularityTableTableRowRowRow
MVCCNoNoYesNoNo
Replication support(note 1)YesLimited(note 9)YesYesYes
Storage limits256TBRAM64TBNone384EB
T-tree indexesNoNoNoNoYes
TransactionsNoNoYesNoYes
Update statistics for data dictionaryYesYesYesYesYes

六 InnoDB和MyISAM比较

功能InnoDBMyISAM
ACID事务
配置ACID属性
崩溃恢复
外键支持
行级锁力度
MVCC

七 InnoDB部分特性

功能支持功能支持
存储限制64TB索引高速缓存
MVCC数据高速缓存
B树索引自适应散列索引
集群索引复制
压缩数据更改数据字典
加密数据地理空间数据类型
查询高速缓存地理空间索引
事务全文搜索索引
锁定粒度集群数据库
外键备份和恢复
文件格式管理快速索引创建
多个缓冲区池PERFORMANCE_SCHEMA
更改缓冲自动故障恢复

八 InnoDB核心要点

  • 表空间
  • ARIES
  • 数据页
  • 内存
  • 线程
  • 状态查询
    • MVCC
    • 锁分类
    • 锁算法
  • 事务
    • 事务
    • 事务特性ACID
    • 事务隔离级别
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
限时福利1:购课进答疑群专享柳峰(刘运强)老师答疑服务 为什么需要掌握高性能MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值