mysql架构图(深入了解Mysql逻辑架构)
mysql架构图
深入了解Mysql逻辑架构mysql现在是大多数公司企业在用的数据库,之所以用mysql,一点是因为mysql是开源软件,一些有能力的公司会基于已有的mysql架构,进行修改、调整改成适合自己公司的业务需要。
一点是因为mysql免费,相对昂贵的oracle服务,对于很多刚起步的公司来说,是最适合不过的数据库了。
之所以要认识mysql的逻辑架构,就好比我们自己在做开发时,首先需要先掌握自己系统用的分层架构,这样在开发的过程中,如果有哪个环节产生问题,就很好排查。认识mysql的逻辑架构也同理,我们在用mysql的时候,我们不清楚它什么时候会出现问题,但是当出现问题时(比如优化查询sql,要从哪一步开始),我们可以更清楚的定位问题。
1.connections 连接器
我们连接mysql的服务作为客户端连接mysql服务端,mysql可以连接各个编程语言平台
2.系统管理和控制工具(management serveices & utilities)
作为mysql服务的管理和控制工具,比如备份、还原、复制、集群等
3.连接池(connection pool)
连接池的主要功能是提供连接认证、线程复用、连接数限制等
4.sql interface(sql接口)
这里主要是接收mysql 的dml、ddl语句,以及存储过程、视图、触发器等
5.parse(解析器)
这里主要的对传过来的sql字符串进行解析,比如我们一开始接触的jdbc编程,就是将字符串类型的sql语句发送到mysql里,然后解析器首先对sql语句进行词法分析,形成语法树,接着再对语法树进行语法分析,看各个分词是否符合sql92标准,符合的话再执行下一环节业务处理。
6.查询优化器(optimizer)
查询优化器根据传过来的sql语句,进行分析判断是否是最优的执行语句,主要针对一下三个方面进行分析:
* 使用哪一个索引(一个表有若干个索引,选择过滤力度最大的那个)
* 多表关联的表连接顺序
* where条件的先后顺序(根据mysql最左前缀原则,会重新摆放条件顺序)
7.查询缓存(cache&buffer)
mysql会将每一条sql进行hash处理后将hash值放到一个map中,每次有sql来时先计算sql的hash值,比较是否相同,相同的话可以执行内存的sql,而不必对新的sql语句进行解析、优化等操作,加快执行效率。
8.存储引擎(pluggable storage engines)
msql的存储引擎支持可插拔特性,即用户可随意替换想用的存储引擎,也可以自定义自己的存储引擎,这里主要针对innodb、myisam存储引擎进行分析比较。
平时涉及到存储引擎的选型,主要针对业务的需要来选择,可以参考各自的特点。
存储引擎的选型:
innodb:
支持事务处理,支持外键,支持崩溃修复能力和并发控制。如果需要对事务的完整性要求比较高(比如银行),要求实现并发控制(比如售票),那选择innodb有很大的优势。如果需要频繁的更新、删除操作的数据库,也可以选择innodb,因为支持事务的提交(commit)和回滚(rollback)。
myisam:
插入数据快,空间和内存使用比较低。如果表主要是用于插入新记录和读出记录,那么选择myisam能实现处理高效率。如果应用的完整性、并发性要求比 较低,也可以使用。
memory:
所有的数据都在内存中,数据的处理速度快,但是安全性不高。如果需要很快的读写速度,对数据的安全性要求较低,不需要持久保存,可以选择memoey。它对表的大小有要求,不能建立太大的表。所以,这类数据库只使用在相对较小的数据库表。
这里有一张mysql的简单执行流程图,凭靠这张图对mysql整体的一个执行流程会有清晰的认识。
mysql的逻辑架构就介绍到这里。当然mysql还有对应的物理架构,不过这一块主要涉及到mysql的各个日志文件,以及各个表的数据文件以及索引文件,在后面的章节再做介绍。
以上就是深入了解mysql逻辑架构的详细内容,更多关于mysql逻辑架构的资料请关注开心学习网其它相关文章!
原文链接:https://www.cnblogs.com/process-h/p/13987069.html
- mysql中定义字段时zerofill属性的作用
- mysql8.0.21的安装步骤(mysql8.0.23 msi安装超详细教程)
- mysql8.0详解(MySQL 8.0 的 5 个新特性,太实用了!)
- mysql各种查询方式(mysql查询的控制语句图文详解)
- python怎么操作mysql(详解Python的数据库操作pymysql)
- mysql binlog模式实际使用(实例验证MySQL|update字段为相同的值是否会记录binlog)
- mysql 主从配置详解(MySQL 8.0.15配置MGR单主多从的方法)
- mysql查看数据库cpu使用率(CPU 以及内存从哪些方面影响 MySQL 性能?)
- mysqlshell日常运维脚本(监控MySQL主从状态的shell脚本)
- mysql索引详解及基本用法(Mysql普通索引与唯一索引的选择详析)
- mysql中的null是什么(浅谈为什么Mysql数据库尽量避免NULL)
- mysql慢日志查询作用(MySQL 慢查询日志的开启与配置)
- mysql锁机制图解(详解mysql 中的锁结构)
- mysql中自增字段类型(MySQL数字类型自增的坑)
- mysql详细学习笔记(Mysql常用命令 详细整理版)
- mysql日志使用(MySQL 日志相关知识总结)
- 14岁丧父 20岁丧母,从苦难走向辉煌的银泰创始人沈国军(14岁丧父20岁丧母从苦难走向辉煌的银泰创始人沈国军)
- 银泰集团董事长沈国军获评 北京影响力 十大企业家(银泰集团董事长沈国军获评)
- 15帅气男士发型,清爽时尚很有型,喜欢就试试(清爽时尚很有型)
- 哪几个历史人物被影协主席李雪健演的活灵活现(哪几个历史人物被影协主席李雪健演的活灵活现)
- 王伦狭隘,晁盖霸道,宋江奸诈骨头软,只有鲁智深才适合当寨主(王伦狭隘晁盖霸道)
- 他是梁山最早的头目,江湖人称 旱地忽律 ,宋江几乎将其遗忘(他是梁山最早的头目)
热门推荐
- sql server 2008自定义函数(SQL SERVER 2012新增函数之逻辑函数CHOOSE详解)
- laravel队列是如何触发的(laravel 事件/监听器实例代码)
- dedecms网站空白(DEDECMS支持中文水印的解决方法)
- h5获取ios系统版本(详解h5页面在不同ios设备上的问题总结)
- 服务异常处理方案(网站出现Service Unavailable提示怎么解决?)
- springboot docker 部署(详解docker部署SpringBoot及替换jar包的方法)
- linux搭建nacos(docker搭建nacos1.3.0的实现)
- h5人脸扫描代码(Html5调用手机摄像头并实现人脸识别的实现)
- mysql索引面试总结(Mysql数据库索引面试题程序员基础技能)
- 云服务器哪个最靠谱(云服务器哪家好?根据需求选配置才最好)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9