百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MySQL运行机制(mysql的运行机制)

nanshan 2024-10-24 11:37 14 浏览 0 评论

  • 建立连接(Connector & Connection Pool)
    • 通过客户端/服务器通信协议与MySQL建立连接,MySQL客户端与服务端的通信方式是”半双工“。
      • "单工"(simplex):单工通信只支持信号在一个方向上传输(正向或反向),任何时候不能改变信号的传输方向。为保证正确传送数据信号,接收端要对接收的数据进行校验,若校验出错,则通过监控信道发送请求重发的信号。
      • "半双工"(half-duplex):半双工通信允许信号在两个方向上传输,但某一时刻只允许信号在一个信道上单向传输。 因此,半双工通信实际上是一种可切换方向的单工通信。
      • "全双工"(full-duplex):全双工通信允许数据同时在两个方向上传输,即有两个信道,因此允许同时进行双向传输。 全双工通信是两个单工通信方式的结合,要求收发双方都有独立的接收和发送能力。

      • Id:线程ID
      • User:执行当前线程的用户
      • Host:发送请求的客户端IP和端口号
      • db:执行当前线程的数据库
      • Command:该线程正在执行的操作命令
        • Create DB:正在创建库操作
        • Drop DB:正在删除库操作
        • Execute:正在执行一个PreparedSTatement
        • Close Stmt:正在关闭一个PreparedStatement
        • Query:正在执行一个语句
        • Daemon:置后台
      • Time:该线程处于当前状态的时间,单位s
      • State:线程状态
        • Updating:正在搜索匹配结果,进行修改
        • Sleeping:正在等待客户端发送新请求
        • Starting:正在执行请求处理
        • Checking table:正在检查数据表
        • Closing table:正在将表中数据刷新到磁盘中
        • Locked:被其他查询lock
        • Sending Data:正在处理select查询,同时将结果发送给客户端
      • Info:记录线程执行的语句,默认显示前100个字符。show full processlist,查看完成的Info信息
  • 查询缓存(Cache & Buffer)
    • 查看查询缓存是否启动、空间大小、限制等
    • 查看更详细的缓存参数,可用缓存空间、缓存块、缓存占用大小等
    • 开启缓存缓存也不会生效的相关命令
      • 查询语句使用SQL_NO_CACHE
      • 查询结果大于query_cache_limit设置
      • 查询中有不确定的参数,比如now()
  • 解析器(Parser)
    • 将客户端发送的SQL进行语句解析,生成"解析数"。预处理器根据MySQL规则检查"解析数"是否合法,最后生成新的"解析数"
  • 查询优化器(Optimizer)
    • 根据"解析数"生成最优的执行计划。优化策略:静态优化(编译时优化)、动态优化(运行时优化)。
      • 等价变换策略:基于无效查询(1=1)、变量查询(a < b and a = 5)、联合索引等的优化
      • 优化count、min、max等函数
        • InnoDB引擎min函数只需要找索引最左边的数据
        • InnoDB引擎man函数只需要找索引最右边的数据
        • MyISAM引擎count(*)直接返回
      • 提前终止查询:使用limit查询,获取limit所需的数据之后,停止遍历后面的数据
      • in的优化:对in查询,会先对in中的数据进行排序,然后再采用二分法查询数据。
  • 查询执行引擎
    • 负责执行SQL语句,会根据表中的存储引擎类型,以及对应的API接口与底层存储引擎缓存/物理文件交互,得到结果并返回客户端。
    • 若开启查询缓存,会将SQL语句和结果完整的保存在查询缓存(Cache & Buffer)中,若再次查询则直接返回结果。
    • 如果需要返回的结果过多,则采用增量模式返回。

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: