MYSQL实战-1.mysql基本架构

1、mysql可分为server层和存储引擎
1.1 server层:
连接器、查询缓存、分析器、优化器 、执行器、包含所有内置函数(日期,时间,数学、加密函数),所有跨存储引擎的功能都在此层,比如存储过程、触发器、视图等
1.1.1 连接器:
负责跟客户端建立连接、获取权限、维持和管理连接
mysql -h$host -P$port -u$user -p$password
备注:
a、sleep状态是连接完成,但没有后续操作,此连接就会处于空闲状态;
b、如果在连接过程中对当前用户的权限做了修改,也需要在断开重新连接之后此权限才生效;
c、长连接与短连接:长连接使用过多会出现mysql内存占用过高导致mysql异常重启的情况,解决方法可以是:定期断开长连接,5.7及以上,则可以通过mysql_reset_connection来重新初始化连接缓存,这个过程不会重连和重新做权限验证,但会恢复到刚刚创建完的状态;
1.1.2 查询缓存:
a. 建立连接之后便会去查询缓存,缓存会以key-value对的形式保存,key是查询语句,value是查询结果。若查询命中缓存,则不需要后续复杂的逻辑。
b. 但查询缓存的失效特别频繁,只要有对一个表的更新,那么此表的缓存就会全部清空,因此不建议使用查询缓存。除非是表的数据变动频率不高的,如系统配置表
c.5.8.0已完全将查询缓存模块删掉
1.1.3 分析器:内建解析树,数据表和数据列是否存在, 别名是否有歧义,如果通过建立一个新的解析树,再提交给优化器
a.词法分析、语法分析
1.1.4 优化器
优化器决定最优sql执行顺序,如最优索引,join表的顺序等
1.1.5 执行器
查询对当前表是否有执行权限,若有权限,打开表,根据表引擎接口执行sql
1.2 存储引擎负责数据的存储和提取,包含InnoDB,MyISAM,Memry等,mysql5.5.5版本以上默认InnoDB 备注:
1、wait_timeout针对非交互式连接;
interaction_timeout针对交互式连接;
通过mysql客户端连接数据库是交互式连接,通过jdbc连接数据库是非交互式连接;
2、执行完成后写入缓存 问题:
1、为什么对权限的检查不在优化器之前做?
答:触发器是在执行器阶段确定的
2、我创建了一个没有select权限的用户,执行select * from T where k=1,报错“select command denied”,并没有报错“unknown column”,是不是可以说明是在打开表之后才判断读取的列不存在?
答:这是一个安全问题,当既没有查询权限,where条件的字段不存在时,未避免泄露太多信心,会直接判断无权限
3、分析器到查询缓存的那个箭头表示什么意思?
答:更新完回来失效缓存;
4、基本架构图中,分析器指向了查询缓存,是这时候把KEY放入缓存的吗?执行器不指向缓存Value是什么时候放入缓存的?
答:其实执行完会写入,避免图乱,箭头去掉了,文中:执行完成后,结果写入查询缓存;
学习笔记:非原著
MYSQL实战-1.mysql基本架构的更多相关文章
- Mysql实现企业级数据库主从复制架构实战
场景 公司规模已经形成,用户数据已成为公司的核心命脉,一次老王一不小心把数据库文件删除,通过mysqldump备份策略恢复用了两个小时,在这两小时中,公司业务中断,损失100万,老王做出深刻反省,公司 ...
- 项目实战7—Mysql实现企业级数据库主从复制架构实战
Mysql实现企业级数据库主从复制架构实战 环境背景:公司规模已经形成,用户数据已成为公司的核心命脉,一次老王一不小心把数据库文件删除,通过mysqldump备份策略恢复用了两个小时,在这两小时中,公 ...
- 《MySQL实战45讲》学习笔记1——MySQL的基础架构
在<极客时间>订阅了<MySQL实战45讲>专栏,总觉得看完和没看一样
- MySQL实战 | 01-当执行一条 select 语句时,MySQL 到底做了啥?
原文链接:当执行一条 select 语句时,MySQL 到底做了啥? 也许,你也跟我一样,在遇到数据库问题时,总时茫然失措,想重启解决问题,又怕导致数据丢失,更怕重启失败,影响业务. 就算重启成功了, ...
- Mysql实战45讲 05讲深入浅出索引(下)极客时间 读书笔记
极客时间 Mysql实战45讲 04讲深入浅出索引(下)极客时间 笔记体会: 回表:回到主键索引树搜索的过程,称为回表覆盖索引:某索引已经覆盖了查询需求,称为覆盖索引,例如:select ID fro ...
- MySQL实战45讲学习笔记:第十五讲
一.引子 在今天这篇答疑文章更新前,MySQL 实战这个专栏已经更新了 14 篇.在这些文章中,大家在评论区留下了很多高质量的留言.现在,每篇文章的评论区都有热心的同学帮忙总结文章知识点,也有不少同学 ...
- 《MySQL实战45讲》(1-7)笔记
<MySQL实战45讲>笔记 目录 <MySQL实战45讲>笔记 第一节: 基础架构:一条SQL查询语句是如何执行的? 连接器 查询缓存 分析器 优化器 执行器 第二节:日志系 ...
- 《MySQL实战45讲》个人笔记-基础篇
拜读了林晓斌大佬的<MySQL实战45讲>,特意做个知识点总结,以便后期回忆. 01.基础架构:一条SQL查询语句是如何执行的? Server 层包括连接器.查询缓存.分析器.优化器.执行 ...
- MySQL高级知识- MySQL的架构介绍
[TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...
随机推荐
- .net core Consul
创建API项目修改Program public class Program { public static void Main(string[] args) { CreateWebHostBuilde ...
- Jmeter性能测试请求超时:目前遇见有三种情况
1.请求连接超时.连不上服务器.一般是因为线程太多 2.连接成功,但是读取超时.等不到服务器返回的数据,一般是这次请求查询的量很大,比如查了5度的顶点.(timeout小于server的最大等待时间) ...
- BAT面试必问题系列:深入详解JVM 内存区域及内存溢出分析
前言 在JVM的管控下,Java程序员不再需要管理内存的分配与释放,这和在C和C++的世界是完全不一样的.所以,在JVM的帮助下,Java程序员很少会关注内存泄露和内存溢出的问题.但是,一旦JVM发生 ...
- 4.Pod控制器
Controller-manager: Kube-controller-manager Cloud-controller-manager:在K8S上启用CloudProvider的时候才需要,用来配合 ...
- java web中乱码的种类和一些解决方式
在java web课堂测试中遇到了一些乱码问题 ,从百度上找到了许多种解决方法和乱码的种类,在这里总结一下. 一.文件出现乱码 [右击文件]->[Properties]->[Resourc ...
- Introduction of Generator in Python
Python中生成器的原理与使用详解 原创牛大财有大才 发布于2018-09-05 14:36:38 0.range() 函数,其功能是创建一个整数列表,一般用在 for 循环中 语法格式:range ...
- 重塑云上的 Java 语言
音乐无国界,但是音乐人有国界. 云原生亦如此.虽没有限定的编程语言,但应用所使用的编程语言已经决定了应用部署运行的行为. Java 诞生于20年前,拥有大量优秀的企业级框架,践行 OOP 理念,更多体 ...
- Quick BI支持哪些数据源(配置操作篇)
Quick BI 潜心打造了核心技术底座(OLAP分析引擎),实现了SQL解析.SQL调度.SQL优化.查询加速等基础能力,支撑Quick BI的数据分析和查询加速.OLAP分析引擎包括数据源连接.数 ...
- 不同地区Android开发者使用哪些设备测试APP?
我们的团队密切关注着移动世界的趋势,以便可以提供所有有关变化的最紧密和最重要的信息.春天恰好是对app进行新一轮测试并检查其与不同Android设备兼容性如何的最佳时机.下面让我们一起来看看全世界范围 ...
- B/S超大文件上传与下载
最近遇见一个需要上传百兆大文件的需求,调研了七牛和腾讯云的切片分段上传功能,因此在此整理前端大文件上传相关功能的实现. 在某些业务中,大文件上传是一个比较重要的交互场景,如上传入库比较大的Excel表 ...