MYSQL查询结果实现发送给客户端

2025-06-11 16:50

本文主要是介绍MYSQL查询结果实现发送给客户端,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MYSQL查询结果实现发送给客户端》:本文主要介绍MYSQL查询结果实现发送给客户端方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教...

MYSQL取数据和发数据的流程(边读边发)

  • 1.服务端,获取一行数据,存到net_buffer中,可以理解为结果集
  • 2.继续读取数据,直到net_buffer写满,调用网络接口发出去
  • 3.如果发送成China编程功,就清空net_buffer
  • 4.如果发送失败,就说明socket send buffer 写满了,进入等待,直到有足够的空间可写,再继续发送。

注意net_buffer满了就发给客户端而不是等查询语句查询完所有数据才发,其中net_buffer默认大小是16k,所以服务器占用内存最多是16k,不会因为查询200G的数据导致内存爆掉。

如果客户端接收数据太慢,就会导致数据在socket send buffer 堆积,导致发送数据到客户端的线程进入等待,由于net_buffer数据没有发送出去,net_buffer一直没法清空,查询语句就要等待net_buffer清空才能继续执行,导致服务端查询速度变慢。

Sending to client

假设使用show processlist发现一条语句的state是“Sending to client”,就是上面说的在等待socket send buffer 有足够空间可以将net_buffer中的数据写进去发送给客户端。

Sending Data

一个查询语句的状态是这样的:

  • 1.首先将语句状态写成Sending Data
  • 2.将查询需要的列信息发送给客户端China编程
  • 3.继续执行查询
  • 4.完成查询,将状态写成空

但是MYSQL8好像改了,我看到的是executing

MYSQL查询结果实现发送给客户端

LRU(Least Recently Used )算法

最近最少使用算法是一种内存淘汰机制,核心是--内存空间不足时,将最少使用的数据页淘汰

innodb管理Buffer Pool android的LRU算法,是通过链表来实现的,每个链表节点就是一个数据页。

  • 1.链表中任意一个数据页被访问到时,就将这个节点放在链表的头节点
  • 2.当访问一个链表中没有的数据页,需要加载到BufferPool并且放在头节点
  • 3.当新节点要进来时,如果链表空间不足了,就把链表尾节点从链表中删除。

但是这个LRU在某些场景时有很大问题的

比如一个语句查询了历史数据表(python非业务热点数据表)的所有数据,这就会把链表中之前维护的热点数据页都淘汰掉,留下一些非业务热点数据页,会导致缓存命中率急剧降低,磁盘IO压力倍增。

针对这种清空,Innodb对LRU算法进行了优化

就是对链表进行了分区,前5/8是young区,后3/8是old区。

  • 1.如果young的数据页被访问到了,和普通LRU算法一样,移到链表头部。
  • 2.如果链表空间满了,此时有个新的数据页要加进来,和普通LRU算法一样首先把链表尾部的数据页淘汰,不过这个新的数据页不是放在链表头部,而是放在old区的第一个位置。
  • 3.对于old区的数据页,每次访问都要进行判断:

如果该数据页在old待的时间大于1秒,就移动到整个链表的头节点。

如果小于1秒,就不改变位置。

这个1秒是由innodb_old_blocks_time参数控制的。

这样一来,短时间内的非热点数据只会存在于old区,一段时间内不被访问就慢慢掉到尾部被淘汰了,不会影响到真正的热点数据,它们会一直在young区。保证了不影响正常业务。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程China编程China编程(www.chinasem.cn)。

这篇关于MYSQL查询结果实现发送给客户端的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155008

相关文章

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin