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中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

MySQL分区表的具体使用

《MySQL分区表的具体使用》MySQL分区表通过规则将数据分至不同物理存储,提升管理与查询效率,本文主要介绍了MySQL分区表的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、分区的类型1. Range partition(范围分区)2. List partition(列表分区)3. H

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)