MyCat-架构剖析-MySQL 协议简介 | 学习笔记

简介: 快速学习 MyCat-架构剖析-MySQL 协议简介

开发者学堂课程【全面讲解开源数据库中间件MyCat使用及原理(三):MyCat-架构剖析-MySQL 协议简介】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/757/detail/13295


MyCat-架构剖析-MySQL 协议简介

Mycat 伪装自己是 MySQL,要想伪装自己,就需要模拟 MySQL 的协议。接下来应用程序在去连接 Mycat 的时候和连接 MySQL 的时候是一样的。这节就来讲解Mycat 如何实现 MySQL 协议。

 

MySQL 协议简介

1.概述

MySQL 协议处于应用层之下、TCP/IP 之上,在 MySQL 客户端和服务端之间使用。包含了链接器、MySQL 代理、主从复制服务器之间通信,并支持 ssL 加密、传输数据的压缩、连接和身份验证及数据交互等。其中,握手认证阶段和命令执行阶段是 MVSOL 协议中的两个重要阶段。

握手认证阶段指的是 MYSQL 的客户端和 MYSQL 的服务端进行交互。握手认证的过程就是建立连接,然后去校验用户名密码的有效性。

命令执行阶段指的是发送一条 SQL 语句给 MySQL 的服务端,MySQL 服务端执行完之后再返回的这个过程就是命令执行。接下来从两个层面:握手认证阶段和命令执行阶段,来给大家分 MySQL 协议都包含了哪些东西。

2.握手认证阶段

image.png

A

握手认证阶段是客户端连接服务器的必经之路,客户端与服务端完成 TCP 的三次握手以后,服务端会向客户端发送一个初始化握手包,握手包中包含了协议版本,MvSQLServer 版本,线程 ID,服务器的权能标识和字符集等信息。

B

客户端在接收到服务端的初始化握手包之后,会发送身份验证包给服务端(AuthPacket),该包中包含用户名、密码等信息。

C

服务端接收到客户端的登录验证包之后,需要进行逻辑校验,校验该登录信息是否正确。如果信息都符合,则返回一个 OKPacket,表示登录成功,否则返回ERR_Packet,表示拒绝。

握手认证阶段细分为三个部分,有三个数据包。这里需要通过抓包工具来抓取MySQL 客户端连接服务端的时候交互的过程,抓包工具叫做 wireshark。

image.png

在 wireshark 当中并没有检测到对应的网卡,这个时候就需要开启 windows 上的抓包服务,以管理员身份运行,后续步骤如下:

image.png

image.png

NPF 服务启动起来了之后,需要重新打开 wireshark。这个时候它就将本地的几块网卡已经下载出来了:

image.png

而这几块网卡实际上和下图所示的本地的网卡是一致的:

image.png

image.png

在抓取的时候就可以选择要抓取的是哪一块网卡上的包。

要抓取的是 MySQL,那么在这一块抓取的时候,应该怎么操作呢?

众所周知,在我们的服务器上,这一块有 157,158,159,160。

image.png

这四个服务器都安装有 MySQL,现在只需要从 windows 上来连。

C:\Windows\system32>mysq1 -h 192.168.192.157 -u root -p

这个时候我们要连的就是 157。

当前 WINDOWS 系统要连接虚拟机服务,由于当前虚拟机在这一块采用的是 NAP模式,所以它所使用的网卡实际上就是 vmNAP8,也就是以太网 4。所以要抓取的则是以太网 4 这一块网卡的信息。双击以太网 4:

image.png

双击进来之后这里所展示的就是以太网4当中的数据包。因为数据量太多了,所以要连接的时候可以先过滤一下:

image.png

过滤条件:image.png

过滤条件是只过滤端口是 3306 的,不管原始端口还是目标端口只要是 3306,都要进行过滤。先把数据清空:

image.png

接下来输入密码 IDCARD:

C:\Windows\system32>mysq1 -h 192.168192.157 -u root -p Enter password:******

Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 204

Server version: 5.6.22-1og MySOL Commnity Server(GPL)

Copyright(c)2000,2014, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners.

Type'help:’or’\h’for help. Type’lc’to clear the current input statement.

mysql>

这样就登录到了 MySQL 中。在这个过程当中,可以看到有很多的数

image.png

据包:

红色线框中,对于当前的 Windows 系统来说,它就是源,就是 192.1,他的IP地址:

image.png

以太网 4 本地的地址是 192.1:

image.png

源是 192.1,目标是 192.157:

第一个是 1 到 157 的,接下来是 157 到 1 的,又是 1 到 157 的。这就是三次握手请求的数据。

在三次握手以后,服务端会向客户端发送一个初始化的握手包,注意是服务端向客户端发送的初始化握手包,服务端是 157,客户端就是 1:image.png

192.157 这个服务端往 192.1 也就是当前 windows 这个客户端发送了一个初始化的数据包,注意它的协议就是 MySQL 协议。

初始化的握手包要做什么事呢?握手信息里面有很多的信息,点击:

image.png

也就是 MySQL 协议。点击:

MySQL Protocol

Packet Length:78

Packet Number: 0

server Greeting

Protocol:10

Version:5.6.22-1og

Thread ID:204

Salt:&^&C]-C.

Server Capabilities:&xf7ff

Server Language: latini COLLATE latin1_swedish_ci(8)

Server status: 0x0002

>Extended Server Capabilities: 0x807f

Authentication Rlugin Length: 21

Unused:0000000000000000000

Salt:WPi?@`Clv/#`

Authentication Plugin: mysql_native_password

综上,wireshark 抓包如下:

image.png

报文分析如下:

1).初始化握手包

通过抓包工具 wireshark 抓取到的握手包信息如下,握手包格式:

image.png

说明:

Packet Length : 包的长度;

Packet Number : 包的序号;

Server Greeting: 消息体,包含了协议版本、MvsOLServer 版本、线程 ID 和字符集等信息。

以上就是所提到的第一个数据包:初始化握手包。

2).登录认证包

客户端在接收到服务端发来的初始握手包之后,向服务端发出认证请求,该请求包含以下信息(由 Wireshark 抓获):

当客户端接收到这个数据包之后,它就会给服务端再发送一个数据包,叫做身份认证信息的数据库。那么身份证信息的数据包在哪?

上面是服务端发送给客户端,接下来客户端又发给服务端一个:

image.png

打开客户端发送给服务端的 MySQL 协议:

image.png

刚才的 packet number 是 0,现在变为 1,因为这是第二个数据包。

Login Request 是登录请求的意思,也就是登录认证包。

登录认证包中主要包含了什么信息呢?最重要的信息:user

登录的时候曾经填写了一个:

image.png

下面还有对应的密码,只不过这个密码是加密之后的。还有字符挤压等信息,这就是第二个数据包,握手认证包。在这个里面就是由我们认证的相关信息。

握手认证包发送给服务端之后,服务端就需要去校验用户名密码。如果校验成功,会返回一个成功的信息:OK packet。如果校验失败,它会返回一个失败的信息ERR packet。

接下来就是握手认证阶段的第三个数据包, OK 包或 ERR 包。

3).OK 包或 ERROR 包

服务端接收到客户端的登录认证包之后,如果通过认证,则返回一个 OKPacket,如果未通过认证,则返回一个 ERROR 包。

因为登录成功之后要返回回去,版本这些信息都是需要反馈过来的。

以上是 ok 的内容,清空掉。

接下来再次登录,打开 cmd,输入:

C:\Users\Administrator>mysq1 -h 192.168.192.157 -u root -p

image.png

看上面的数据大家会发现,虽然还没有进行登录但是还是会有很多的这个数据包。原因是这块网卡当中还有一些其他的信息,比如 157 和 158 之间的交互,158 和 157 之间的交互都是要通过它来进行的。

下面再把它清空掉。进行登录操作:

打开 cmd,随便输入一个错误的密码

C:\Users\Administrator>mysq1 -h 192.168.192.157 -u root -p Enter password: ***

ERROR 1045(28000): Access denied for user ’root’@’192.168.192.1’(using password: YES)

C:\Users\Administrator>

综上,ERROR 报文如下:

image.png 

以上就是握手认证阶段的内容,分为三个过程:

服务端需要给客户端初始化握手包

客户端需要发送身份证信息给服务端

身份证信息校验,在客户端进行校验,然后会给客户端返回成功或者是错误的一个数据包给客户端

3.命令执行阶段

登录成功之后就可以执行一系列的命令。首先看一下数据库,输入show databases:

image.png

大家会发现里面是有数据库的,这个阶段有对应的数据包,也可以通过抓包工具来进行抓取。

清空,选择不保存:

image.png

当执行 show databases 时,当前 Windows 给服务器 157,在这发送的指令来执行查询操作,查询所有的数据。

这个时候大家要来抓数据包:

image.png

192.1 到 192.157 这一块的数据包。看一下这个数据包当中的信息:

image.png

头信息不用看,然后是 command 查询。 show databases 指令,circle 语句:show databases。

这就是当前客户端发送给服务端的数据包。那服务端返回给客户端的结果又是怎么样呢?

192.157 到 192.1 这个数据的数据包里有很多信息

在握手认证阶段通过并完成以后,客户端可以向服务端发送各种命令来请求数据,此阶段的流程是:命令请求->返回结果集

wireshark 捕获的数据包如下:  

96 90.388877 192 168.1921 19119157M 89 Request Query——>命令请求

97 90.404622 192168.192.157192168.192.1Myo 287 Response——> 返回结果集

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
7月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
6月前
|
关系型数据库 MySQL 分布式数据库
Super MySQL|揭秘PolarDB全异步执行架构,高并发场景性能利器
阿里云瑶池旗下的云原生数据库PolarDB MySQL版设计了基于协程的全异步执行架构,实现鉴权、事务提交、锁等待等核心逻辑的异步化执行,这是业界首个真正意义上实现全异步执行架构的MySQL数据库产品,显著提升了PolarDB MySQL的高并发处理能力,其中通用写入性能提升超过70%,长尾延迟降低60%以上。
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
10月前
|
数据可视化 关系型数据库 MySQL
嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议数据可视化
通过本文的介绍,我们详细讲解了如何结合嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议,实现数据的采集、传输、存储和可视化。这种架构在物联网项目中非常常见,可以有效地处理和展示实时数据。希望本文能帮助您更好地理解和应用这些技术,构建高效、可靠的数据处理和可视化系统。
600 82
|
11月前
|
存储 关系型数据库 MySQL
MySQL索引学习笔记
本文深入探讨了MySQL数据库中慢查询分析的关键概念和技术手段。
735 81
|
6月前
|
关系型数据库 MySQL 网络安全
MySQL 深潜 - X-plugin的传输协议
文章详细解析了X protocol的认证方式(如PLAIN、MYSQL41等)、协议格式及连接建立过程,包括服务端初始化、任务调度、请求处理等关键步骤,并结合代码示例说明认证流程。
|
8月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
10月前
|
SQL 存储 缓存
MySQL的架构与SQL语句执行过程
MySQL架构分为Server层和存储引擎层,具有高度灵活性和可扩展性。Server层包括连接器、查询缓存(MySQL 8.0已移除)、分析器、优化器和执行器,负责处理SQL语句;存储引擎层负责数据的存储和读取,常见引擎有InnoDB、MyISAM和Memory。SQL执行过程涉及连接、解析、优化、执行和结果返回等步骤,本文详细讲解了一条SQL语句的完整执行过程。
350 3
|
SQL 存储 缓存
【赵渝强老师】MySQL的体系架构
本文介绍了MySQL的体系架构,包括Server层的7个主要组件(Connectors、Connection Pool、Management Service & Utilities、SQL Interface、Parser、Optimizer、Query Caches & Buffers)及其作用,以及存储引擎层的支持情况,重点介绍了InnoDB存储引擎。文中还提供了相关图片和视频讲解。
434 2
【赵渝强老师】MySQL的体系架构
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。

推荐镜像

更多