mysql冷热数据分离方案(MySQL中使用流式查询避免数据OOM)
mysql冷热数据分离方案
MySQL中使用流式查询避免数据OOM目录
- 一、前言
- 二、JDBC实现流式查询
-
三、性能测试
- 3.1. 测试大数据量普通查询
- 3.2. 测试大数据量流式查询
- 3.3. 测试小数据量普通查询
- 3.4. 测试小数据量流式查询
- 四、总结
一、前言
程序访问MySQL
数据库时,当查询出来的数据量特别大时,数据库驱动把加载到的数据全部加载到内存里,就有可能会导致内存溢出(OOM)。
其实在MySQL
数据库中提供了流式查询,允许把符合条件的数据分批一部分一部分地加载到内存中,可以有效避免OOM;本文主要介绍如何使用流式查询并对比普通查询进行性能测试。
二、JDBC实现流式查询
使用JDBC的PreparedStatement/Statement
的setFetchSize
方法设置为Integer.MIN_VALUE
或者使用方法Statement.enableStreamingResults()
可以实现流式查询,在执行ResultSet.next()
方法时,会通过数据库连接一条一条的返回,这样也不会大量占用客户端的内存。
|
public int execute(String sql, boolean isStreamQuery) throws SQLException { Connection conn = null ; PreparedStatement stmt = null ; ResultSet rs = null ; int count = 0 ; try { //获取数据库连接 conn = getConnection(); if (isStreamQuery) { //设置流式查询参数 stmt = conn.prepareStatement(sql, ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY); stmt.setFetchSize(Integer.MIN_VALUE); } else { //普通查询 stmt = conn.prepareStatement(sql); } //执行查询获取结果 rs = stmt.executeQuery(); //遍历结果 while (rs.next()){ System.out.println(rs.getString( 1 )); count++; } } catch (SQLException e) { e.printStackTrace(); } finally { close(stmt, rs, conn); } return count; } |
「PS」:上面的例子中通过参数isStreamQuery
来切换「流式查询」与「普通查询」,用于下面做测试对比。
三、性能测试
创建了一张测试表my_test
进行测试,总数据量为27w
条,分别使用以下4个测试用例进行测试:
- 大数据量普通查询(27w条)
- 大数据量流式查询(27w条)
- 小数据量普通查询(10条)
- 小数据量流式查询(10条)
3.1. 测试大数据量普通查询
|
@Test public void testCommonBigData() throws SQLException { String sql = "select * from my_test" ; testExecute(sql, false ); } |
3.1.1. 查询耗时
27w 数据量用时 38 秒
3.1.2. 内存占用情况
使用将近 1G 内存
3.2. 测试大数据量流式查询
|
@Test public void testStreamBigData() throws SQLException { String sql = "select * from my_test" ; testExecute(sql, true ); } |
3.2.1. 查询耗时
27w 数据量用时 37 秒
3.2.2. 内存占用情况
由于是分批获取,所以内存在30-270m波动
3.3. 测试小数据量普通查询
|
@Test public void testCommonSmallData() throws SQLException { String sql = "select * from my_test limit 100000, 10" ; testExecute(sql, false ); } |
3.3.1. 查询耗时
10 条数据量用时 1 秒
3.4. 测试小数据量流式查询
|
@Test public void testStreamSmallData() throws SQLException { String sql = "select * from my_test limit 100000, 10" ; testExecute(sql, true ); } |
3.4.1. 查询耗时
10 条数据量用时 1 秒
四、总结
MySQL 流式查询对于内存占用方面的优化还是比较明显的,但是对于查询速度的影响较小,主要用于解决大数据量查询时的内存占用多的场景。
「DEMO地址」:https://github.com/zlt2000/mysql-stream-query
到此这篇关于MySQL中使用流式查询避免数据OOM的文章就介绍到这了,更多相关MySQL 流式查询内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://segmentfault.com/a/1190000038792484
- mysql有什么索引(MySQL 普通索引和唯一索引的区别详解)
- mysql 死锁查询(MySQL slave 延迟一列 外键检查和自增加锁)
- mysql读写分离怎么做(MySQL读写分离,写完读不到问题如何解决)
- mysql主从复制时突然来了一批数据(MySQL主从复制断开的常用修复方法)
- 宝塔数据库不小心删了(宝塔面板MySQL数据库经常自动停止的解决方法)
- mysql对null值如何理解(MySQL为Null会导致5个问题个个致命)
- mysql带log的版本(聊聊MYSQL中Redo Log是什么?)
- mysql日期用法(MySQL DATE_ADD和ADDDATE函数实现向日期添加指定时间间隔)
- mysql 高级用法(MySQL实现replace函数的几种实用场景)
- mysql流式查询(MySQL全面瓦解之查询的正则匹配详解)
- MySQL中ROUND四舍五入函数需要注意的地方
- 用mysql语句写python学生管理系统(Python基于mysql实现学生管理系统)
- mysql什么是慢查询(MySQL慢查询的坑)
- centos7可以装mysql吗(详解腾讯云CentOS7.0使用yum安装mysql及使用遇到的问题)
- pythonmysql使用教程(Python异步操作MySQL示例使用aiomysql)
- mysql的四种关系运算(详解MySQL拼接函数CONCAT的使用心得)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
热门推荐
- python多线程并发使用场景(对python多线程SSH登录并发脚本详解)
- 让服务器iis支持.apk文件下载的设置方法(让服务器iis支持.apk文件下载的设置方法)
- docker 各种用法(详解Docker commit的使用)
- 最全js面试题(JavaScript必看的10道面试题总结推荐)
- php面向对象运用场景(PHP面向对象类型约束用法分析)
- mysql账户访问权限(MySQL 权限控制详解)
- 怎么python爬取网页图片(详解Python静态网页爬取获取高清壁纸)
- 快速建站指南(西部数码建站助手使用图文教程)
- python分析excel基础数据生成报表(Python实现定制自动化业务流量报表周报功能XlsxWriter模块)
- python在dataframe添加数据(使用Python向DataFrame中指定位置添加一列或多列的方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9