当前位置: 首页 > article >正文

18 大量数据的异步查询方案

在分布式的应用中分库分表大家都已经熟知了。如果我们的程序中需要做一个模糊查询,那就涉及到跨库搜索的情况,这个时候需要看中间件能不能支持跨库求交集的功能。比如mycat就不支持跨库查询,当然现在mycat也渐渐被摒弃了(没有处理笛卡尔交集的问题),基本上都选shradingjdbc了。我们暂时不讨论数据库中间件的技术选型问题,讨论下我们一般面对海量数据的查询问题。

我们知道在数据库中的模糊查询需要全盘扫描,找的匹配的字符并返回,性能上就会比较慢,特别是数据量比较大的时候就是一个灾难。这个时候我们一般选择使用elasticsearch倒排索引去做模糊查询的中间件。es通过把字段进行分词操作,并把分词的元字段存储起来。通过分词映射到实际数据的方式避免全盘扫描的问题,如果是海量数据,es的存储压力比较大,那么我们把海量数据存储在分析型数据库中即可。如下图所示:
在这里插入图片描述

关于分析型数据库的列式存储不同数据库的实现不同,有兴趣的可以去了解下。主流的两种hbase和clickhouse,千亿条数据查询也是很快的,但是分析型数据库对修改的操作性能非常差,我们使用的时候注意这一点就可以了。这里不做细究。

我们在java程序中查询的时候通过es的分词找的数据实体,然后需要找全量数据的时候再到分析型数据库中查询即可。这样就可以解决海量数据查询的性能问题


http://www.kler.cn/a/526183.html

相关文章:

  • 芯片AI深度实战:进阶篇之vim内verilog实时自定义检视
  • 【数据结构】二叉树
  • 最新-CentOS 7 基于1 Panel面板安装 JumpServer 堡垒机
  • 网络爬虫学习:应用selenium获取Edge浏览器版本号,自动下载对应版本msedgedriver,确保Edge浏览器顺利打开。
  • 【已解决】黑马点评项目Redis版本替换过程的数据迁移
  • 生成模型:扩散模型(DDPM, DDIM, 条件生成)
  • Win11下帝国时代2无法启动解决方法
  • 安卓(android)实现注册界面【Android移动开发基础案例教程(第2版)黑马程序员】
  • JavaScript - Web APIs(下)
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.25 视觉风暴:NumPy驱动数据可视化
  • FFmpeg源码:av_base64_decode函数分析
  • Python练习(2)
  • 超级强大的压缩和解压工具,免费解压
  • Autosar-Os是怎么运行的?(时间保护)
  • C语言自定义数据类型详解(二)——结构体类型(下)
  • 基于STM32的轮式移动机器人教学
  • olloama下载deepseek-r1大模型本地部署
  • BypassWAF--基本概念
  • Cocoa和Cocoa Touch是什么语言写成的?什么是Cocoa?编程语言中什么是框架?为什么苹果公司Cocoa类库有不少NS前缀?Swift编程语言?
  • [EAI-026] DeepSeek-VL2 技术报告解读
  • 蓝桥云客 三羊献瑞
  • 4.装饰模式(Decorator)
  • Day07:缓存-数据淘汰策略
  • Springboot如何使用面向切面编程AOP?
  • 【Linux系统】进程间通信:实现命名管道通信
  • Linux:基础IO(一.C语言文件接口与系统调用、默认打开的文件流、详解文件描述符与dup2系统调用)