第一章——小白入门

发布于:2024-05-05 ⋅ 阅读:(25) ⋅ 点赞:(0)

《MySQL 是怎样运行的:从根儿上理解 MySQL》

MySQL的客户端/服务器架构

前面的安装基本上等有了

直接执行这一步:

mysql -hlocalhost -uroot -p123456

想要断开客户端与服务器的连接并且关闭客户端的命令

quit
exit
\q

客户端与服务器连接的过程

客户端和服务器本质上都是一个进程,所以客户端向服务器请求并受到回复的过程本质上是一个进程间的通信

TCP/IP

服务器和客户端通过一个统一的协议来进行通信——TCP协议

每个计算机都有一个唯一的IP地址

如果某个进程需要采用TCP协议进行网络通信方面的需求,可以向操作系统申请一个端口号

所以,实际通信的时候,我们是通过IP地址+端口号的方式与进程进行连接

MySQL服务器 会默认申请3306端口

使用TCP/IP协议来启动客户端程序

mysql -h127.0.0.1 -uroot -P3307 -p123456

服务器处理客户端请求

客户端向服务器进程发送一段文本(Mysql语句),服务器进程处理后再向客户端发送一段文本(处理结果)

以下是这个过程的图解

接下来我们来认识以下这三个部分:连接管理,解析与优化,存储引擎

第一部分:连接管理

每当有一个客户端进程连接到服务器进程的时候,服务器进程都会创建一个线程来专门处理与这个客户端的交互。但是当客户端断开连接,服务器并不会丢弃这个线程,而是将这个线程 缓存起来,当下一个客户端连接的时候,使用这个缓存的线程

客户端需要提供主机信息 ,用户名,密码。程序会对客户端程序提供的这些信息进行认证。

如果客户端和服务器不在一台计算机上,我们使用SSL的网络连接进行通信,来保证数据传输的安全性

第二部分:解析与优化

  • 查询缓存

如果查询请求相同的话,会从缓存中返回相同的结果,但是只要查询请求在任何字符上的不同,都会导致缓存不会命中

还有一些情况是不会被缓存的,如mysql,informationschema,performanceschema数据库中的表,用户自定义变量和函数。这个请求不会被缓存

MySQL的缓存系统会检测设计的每张表,如果有张表结构或这数据被修改,使用了如下命令:

UPDATE,DELETE,TRUNCATE TABLE,ALTER TABLE,DROP TABLE,DROP DATABASE语句

小提示:

维护缓存需要造成开销,比如每次都要去查询缓存中的检索,然后又要更新这个缓存,维护该缓存对应的缓存区域。在Mysql8.0中删除

语法解析

如果没有缓存就会到这一步

  • 判断mysql语句是否正确

  • 从文本中将要查询的表,各种查询条件都提取出来放到Mysql服务器内部使用的一些数据结构上来

提取信息的本质是一个编译过程,我们只需要了解它涉及了此法解析,语法解析,语义分析这些阶段就行了

查询优化

语法解析之后,面对我们写的mysql语句执行效率不会太高的问题,mysql的优化程序会对我们的语句进行一些优化,优化 的结果就是生成一个执行计划

我们可以使用EXPLAIN语句来查看某个语句的执行计划

存储引擎

我们在这之前并没有访问过真正的数据表,Mysql服务器把数据的存储和提取操作都封装到了存储引擎中

Mysql提供了各式各样的存储引擎,不同的存储引擎管理的存储结构可能不同,采用的存取算法也可能不同

功能:接收上层传下来的指令,然后对表中的数据进行提取或写入操作

我们将连接管理,查询缓存,语法解析,查询优化这些没有涉及真实数据存储的功能划分为MySQL server的功能

把真实存取数据的功能划分为存储引擎 的功能

各种各样的存储引擎为上层的server提供统一的调用结果口,包含了几十个底层函数

我们先了解最常用的存储引擎吧:

innoDB and MyISAM

InnoDB 具备外键支持功能的事务存储引擎

MyISAM 主要的非事务处理存储引擎

有关存储引擎的一些操作:

  • support表示该存储引擎是否可用

  • DEFAULT表示档期那服务器程序的默认引擎

  • Comment列是对存储引擎的一个描述

  • Transactions列代表该存储引擎是否支持事务处理

  • XA列表示存储引擎是否支持分布式事务

一句话解释一下分布式:多个进程在不同的位置对同一个共享资源进行操作

创建表时指定存储引擎

CREATE TABLE 表名(
  建表语句;
  )ENGINE = 存储引擎名称;

首先我们需要选择一个数据库

use 数据库名

修改表的存储引擎(用小写没关系,系统会自动帮你变成大写的)

alter table 表名 engine = 存储引擎名称

格式:

show create table 表名/G