目录

1、学习笔记之mysql体系结构(C/S架构)

2、mysql整体架构

3、存储引擎

4、sql语句处理--SQL层(内存层)

5、服务器内存结构

6、mysql如何使用磁盘空间

7、mysql物理存储结构

8、mysql逻辑存储结构

学习笔记之mysql体系结构(C/S架构)

  

一、客户端

常用命令都在mysql data根目录下的bin目录;

(1)最大用户连接数

  

  一个连接数占512KB~64MB 内存

二、mysql整体架构(服务器进程架构)

  

  简化如下图:

  

  

 1、连接层

  

  (1)一个用户连接表示一个会话,一个会话要用一个线程来服从os的调度,要做上下文切换,创建销毁会话开销比较大。。所以Mysql这里搞了一个连接池,也就是thread-pool ,也就是再上面那张图的connectors Pool。

 2、SQL层

  通过该接口客户端连接发DML过来;

  

  它做语法语义等各种解析,如下图:

  

  然后优化,把解析后的数据生成mysql可以识别的数据,根据统计信息等等各种信息,优化其执行方式,生成执行计划;

  

3、存储引擎

  就是INNODB,详情可以参考上一篇文章。

  

4.sql语句处理--SQL层(内存层)

       

          

(1)检查告诉缓存查询;(查看查询缓存预设大小)

下面的query_cache_type目前是OFF,证明默认是关闭的,也就是没有启用查询缓存功能。

  

(2)解析查询

  【1】硬解析:第一次执行  【2】软解析:如果以前有解析过同样的语句,这里就不再解析,直接拿以前的来用。

5、服务器内存结构

  

  (1)连接/会话:这是每个线程私有的(相当于Oracle中的PGA),当内存不够的时候,才会用到临时表

  

  (2)服务器/共享:

    【1】查询高速缓存:就是我们查询结果的结果集要缓存起来  【2】线程高速缓存:就是连接信息缓存

  (3)存储引擎/共享:

    【1】日志缓冲区:redo/undo等日志缓冲  【2】缓冲池:数据缓冲(如index page/data dictionary/insert buffer/hash page)

内存参数如下:

    

(1) 连接/会话

  【1】join_buffer_size :表连接内存  【2】sort_buffer_size:表排序内存  【3】temp_table_size:内存不够用了,用临时表存储(磁盘),临时表大小

(2)服务器/共享

  【1】query_cache:结果集缓存  【2】table_cache:打开每个表的信息缓存起来,以后要用每个表就不用每次都重新打开了

(3)存储引擎/共享

  【1】innodb_buffer_pool_size:innoDB存储引擎缓冲池大小,应该占内存的50%~80%  【2】innodb_log_buffer_size:日志缓冲大小

6.mysql如何使用磁盘空间

  

(1)查看数据存放目录

  show variables like '%datadir%';   #查看数据存放目录

  show variables like '%log%'    #查看日志存放目录

  

7.mysql物理存储结构

  

(1)查看一下数据库

  【1】查看数据目录  【2】退出mysql进入mysql数据目录  【3】找到数据库

  

 在Mysql里面验证一下;

  

  发现我们看到的3个数据库都有,但多了一个Information_schema,因为该数据库是内存里的东西,所以在数据目录里看不到。

(2)创建一个数据库

create database jfedu default character set utf8;

  

  然后我们可以看到这里有我们新建数据库对应的文件了。

  然后cd 进去看看有什么文件?文件内容是什么

  

  原来就一个文件,文件内容只是字符集和排序规则;

(3)建一个表

  我们切换数据库上下文到新建的数据库jfedu,然后创建一个名为teacher的表;

  

  然后我们看看数据文件里面;

 

  

  因为这里默认存储引擎是innoDb,所以和我们以前写的MYISAM文件体系不一样,这里把MYD和MYI合并成了ibd文件。

  

8、mysql逻辑存储结构

  

(1)1个实例对应一个数据库整体

  1个实例对应的是一个基准数据库(注意这里说的是整体概念,而不是create database那种数据库),其实也可以理解成物理上对应一个mysql目录,指的是下图框出的这个:

  

(2)1个实例对应多个逻辑数据库,1个逻辑数据库对应1个schema

  这里的逻辑数据库说的是这个,应该可以理解;

  

  我们重点说一下逻辑数据库对应的schema,他们是1对1的关系。或者说完全是等价关系。(但在oracle中,schema是用户,在sql server中schema是一个逻辑分组架构。)

(1.3)学习笔记之mysql体系结构(C/S整体架构、内存结构、物理存储结构、逻辑结构)的更多相关文章

  1. (1.1)学习笔记之mysql体系结构(内存、进程、线程)

    关键词:mysql体系结构 参考:https://www.cnblogs.com/zhoubaojian/articles/7866292.html 一.mysql体系架构概述 1.mysql体系结构 ...

  2. (1.2)学习笔记之mysql体系结构(数据库文件)

    InnoDB存储引擎体系结构图 1.InnoDB数据库的结构 (1)redo log:这里的redo log不是数据的redo log,InnoDB本也是一个数据库,身具有的redo log,所以这里 ...

  3. RocketMQ学习笔记(7)----RocketMQ的整体架构

    1. RocketMQ主要的9个模块,如图: 2. 模块介绍 1. rocketmq-common:通用的常量枚举,基类方法或者数据结构,按描述的目标来分包,通俗易懂.报名有admin,consume ...

  4. 学习笔记:oracle学习一:oracle11g体系结构之物理存储结构

    目录 1.物理存储结构 1.1 数据文件 1.2 控制文件 1.3 日志文件 1.3.1 重做日志文件 1.3.2 归档日志文件 1.4 服务器参数文件 1.4.1 查看服务器参数 1.4.2 修改服 ...

  5. SQLMAP学习笔记2 Mysql数据库注入

    SQLMAP学习笔记2 Mysql数据库注入 注入流程 (如果网站需要登录,就要用到cookie信息,通过F12开发者工具获取cookie信息) sqlmap -u "URL" - ...

  6. ref:学习笔记 UpdateXml() MYSQL显错注入

    ref:https://www.cnblogs.com/MiWhite/p/6228491.html 学习笔记 UpdateXml() MYSQL显错注入 在学习之前,需要先了解 UpdateXml( ...

  7. JUC源码学习笔记4——原子类,CAS,Volatile内存屏障,缓存伪共享与UnSafe相关方法

    JUC源码学习笔记4--原子类,CAS,Volatile内存屏障,缓存伪共享与UnSafe相关方法 volatile的原理和内存屏障参考<Java并发编程的艺术> 原子类源码基于JDK8 ...

  8. MySQL笔记(1)---MySQL体系结构和存储引擎

    1.前言 本系列记录MYSQL数据库的一些结构和实现特点,方便查询. 2.基本概念 数据库:物理操作系统文件或者其他形式文件类型的集合.MySQL中数据库文件可以是frm.MYD.MYI.ibd结尾的 ...

  9. 巨杉学习笔记 | SequoiaDB MySQL导入导出工具使用实战

    本文来自社区用户投稿,感谢这位小伙伴的技术分享 巨杉数据库架构简介 巨杉数据库作为分布式数据库是计算和存储分离架构,由数据库实例层和存储引擎层组成的.存储引擎层负责数据库核心功能比如数据读写存储以及分 ...

随机推荐

  1. 【读书笔记】:MIT线性代数(1):Linear Combinations

    1. Linear Combination Two linear operations of vectors: Linear combination: 2.Geometric Explaination ...

  2. git 更新代码

    https://jingyan.baidu.com/album/ab69b2707882f52ca7189f14.html?picindex=7 git commit:将本地修改过的文件提交到本地库 ...

  3. 绿盟扫出来个http host 漏洞

    这个漏洞搞了大半天,想过从后台拦截,也想过从前台拦截,都是无从下手!网上也找了很多资料,有点乱,后来自己结合网上的办法,搞出如下解决办法:在tomcat server.xml里配置host 因为外网是 ...

  4. leetcode.分治.241为运算表达式设计优先级-Java

    1. 具体题目 给定一个含有数字和运算符的字符串,为表达式添加括号,改变其运算优先级以求出不同的结果.你需要给出所有可能的组合的结果.有效的运算符号包含 +, - 以及 * . 示例 1: 输入: & ...

  5. P3391 文艺平衡树(Splay)

    题目背景 这是一道经典的Splay模板题--文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1, ...

  6. 用户Bug修补报告

    用户Bug修补报告 虽然经过许多天的奋斗,我们的U-Help已经正式投入使用,不过在使用过程中遇到了大大小小的问题,我们通过努力修补了其中的相当一部分,以下是用户Bug修补报告. 7.31:发布bet ...

  7. getopts的错误报告模式

  8. 关键字group by 、 Having的 用法

    概述 GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类似Excel里面的透视表. GRO ...

  9. Cisco基础(二):三层交换vlan间通信、多交换机vlan间通信、三层交换配置路由、RIP动态路由配置、三层交换配置RIP动态路由

    一.三层交换vlan间通信 目标: VLAN实现了广播域的隔离,同时也将VLAN间的通信隔离了.三层交换技术使得VLAN间可以通信. 通过三层交换实现VLAN间通信 方案: 为了解决了传统路由器低速. ...

  10. 巴厘岛的雕塑(sculptures)

    巴厘岛的雕塑(sculptures) 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 1 到 N 连续地进行标号,其中第 i ...