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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配