【MySQL】MySQL是如何传输数据的?

1. 客户端-服务器通信(连接层)

MySQL 客户端(如 mysql 命令行、GUI 工具或应用程序)与 MySQL 服务器之间通过网络本地套接字进行通信。

1.1 本地和远程通信协议:TCP/IP(Transmission Control Protocol/Internet Protocol)

(1)TCP/IP是互联网的基础通信协议,用于 本地(LAN)远程(WAN) 的数据传输。它包含:

  • IP(Internet Protocol,互联网协议):负责寻址和路由数据包。
  • TCP(Transmission Control Protocol,传输控制协议):提供可靠的端到端通信,确保数据不丢失、不重复、按顺序到达。

(2)使用IP 地址 & DNS 主机名来识别主机

  • IP 地址 :用于唯一标识网络中的设备(如 192.168.1.100)。
  • DNS(域名系统) :将主机名(如 mysql.example.com)解析为 IP 地址,方便访问远程服务器。

(3)使用TCP 端口号区分同一主机上的不同服务。

(4)本地通信:同一台主机内 进程之间的通信,常用于进程间通信(IPC)测试网络服务

  • 仅在 本机 上运行的进程间通信,不经过物理网卡

  • 使用 回环地址(127.0.0.1) 进行通信。

  • 低延迟、高速、安全,不会经过外部网络。

  • 通过 Unix Socket127.0.0.1:3306 进行连接。

    bash 复制代码
    mysql -u root -p -h 127.0.0.1 -P 3306

    如果使用 --host=localhost,MySQL 可能会使用 Unix 套接字连接,而不是 TCP。

(5)远程通信:不同设备间通过 TCP 进行通信,通常使用 公网 IP(如 8.8.8.8)或局域网 IP(如 192.168.1.100)

  • 需要网络连接(局域网或互联网)。
  • 可能受到防火墙、NAT 限制。
  • 存在一定的网络延迟。
  • 可能需要身份验证、加密保护(如 SSH、TLS)。

1.2 本地通信协议:Socket

(1)Socket 主要用于同一台计算机上进程间通信(IPC),可以通过:

  • Unix 域套接字(UDS):不使用IP地址和端口, 基于 文件路径 通信(如 /tmp/mysqld.sock)。只在 Linux/macOS 可用(Windows 没有 UDS)。低延迟,高性能,比 TCP 更快。
  • 本地TCP套接字: 使用 127.0.0.1 作为 IP 地址。支持所有操作系统,性能稍低于 Unix 套接字
  • 本地UDP套接字: 使用 127.0.0.1 作 IP 地址,UDP 是无连接的协议,适用于实时通信(如游戏、本地日志传输)。适合小数据传输,但可能丢包。
  • 使用/var/lib/mysql/mysql.sock 套接字文件的示例:
bash 复制代码
 mysql -S /var/lib/mysql/mysql.sock -uroot -p
  • 使用默认套接字文件/tmp/mysql.sock 的示例:

    bash 复制代码
     mysql -uroot -p

    如果没有指定主机,mysql 假定-h localhost

1.3 SSL

连接层在可用时使用安全、加密的连接SSL。

  • 如果服务器主机上安装了OpenSSL,MySQL包安装程序将创建SSL密钥,安装程序调用mysql_ssl_rsa_setup 实用程序来创建密钥,如果从二进制存档安装,需要手动调用此实用程序。
  • 如果密钥可用,MySQL客户机将使用SSL,密钥位于数据目录中,将客户端密钥复制到远程客户端以启用加密的远程连接。
  • 如果SSL不可用,则连接将不加密,可以将服务器和客户机配置为强制使用SSL。

1.4连接线程

在 MySQL 默认模式 下,每个客户端连接都会创建一个 独立的服务器线程 来处理 SQL 语句。然而,在高并发场景下,这种模式会带来线程创建和销毁的开销,导致性能下降。

为了解决这个问题,MySQL 提供了 线程池(Thread Pool) ,它分离连接管理线程管理, 通过线程组(Thread Group) 共享线程资源,提高服务器的可扩展性和并发处理能力。

(1)线程池插件管理连接和服务器线程:

  • 线程池不会为每个连接创建独立线程,而是通过线程组(Thread Group)共享线程。
  • 连接请求进入线程池 等待调度 ,然后由可用线程 处理 SQL 语句。

(2)线程组(Thread Group)

  • 每个线程组 处理多个客户端连接,但 任何时刻只允许一个线程运行一个短时 SQL 语句
  • 短时语句优先,避免长时间 SQL 语句阻塞其他查询。

(3)事务优先级管理

  • 运行中的事务具有高优先级,保证事务一致性和响应速度。
  • 长时间运行的事务不会阻塞短语句,提高数据库吞吐量。
相关推荐
落落落sss9 分钟前
nexus的使用
服务器·数据库·mongodb·云原生·eureka
熊文豪22 分钟前
崖山数据库(YashanDB)部署全流程详解
数据库·崖山数据库·yashan·崖山数据库部署全流程·yasboot·yassql·yca认证
野生派蒙22 分钟前
MySQL 安装配置(完整教程)
数据库·mysql
度假的小鱼26 分钟前
Win11系统下Oracle11g数据库下载与安装使用教程
数据库·oracle11g安装·oracle11g下载
溟洵26 分钟前
【MySQL】事务是个啥?(一文带你了解 为什么要有事务、事务在mysql中的出现情况以及事务的四大特性)
linux·运维·数据库·后端·mysql
小明同学的开发日常27 分钟前
【Spring AI】05. 向量数据库-Redis
数据库·人工智能·spring
m0_5485147729 分钟前
五款MySQL 可视化客户端软件,你选择哪一种?
数据库·mysql
ljh5746491191 小时前
mysql select distinct 和 group by 哪个效率高
数据库·mysql
jsxztshaohaibo1 小时前
Token登录授权、续期和主动终止的方案(Redis+Token(非jwtToken))
java·数据库·redis·缓存
啥都不会的小泽1 小时前
MariaDB 10.6.21(安装后实际版本为10.6.19)
数据库·mariadb