大数据量查询计算引发数据库CPU告警问题复盘

  • 一、背景
  • 二、根因分析
  • 三、解决方案
    • 方案1:多线程+缓存
    • 方案2:利用中间表+缓存
  • 四、总结

一、背景

2025年7月份某天,CDP系统每天不定时推送我们的Portal服务,生产环境运营看板会展示统计数据,发现接口响应缓慢,随之而来数据库监控告警,发现数据库CPU达到了80%。由于表数据量大,计算统计复杂,多线程使用不当,导致数据库服务器爆表。
其中A表数据量达到1亿多,B表数据量600w+,C表数据量30w+,D表数据量400w+.

二、根因分析

1:涉及A、B、C、D四张表的关联查询,数据量巨大。
2:页面查询条件组合较多,初步估计数据量10亿+,而且日期条件多变,无法使用预计算方式提升查询效率。
3:CDP不定时同步,导致每次存量数据无法基线,增量数据的统计依赖于存量数据,故无法使用增量方式计算结果。
4:1次查询搜索,会调用6个接口,1个接口查询数据库6+次,整体耗时较久。

三、解决方案

方案1:多线程+缓存

1:前端查询接口,先查询缓存,如果查询到则直接返回结果。如果查询不到,再查询缓存并将结果更新到缓存中。
2:在后端接口计算中,采用多线程方式,并行计算,然后再统计结果。
3:但是这个方案有个弊端是在缓存中查询不到时候还会查询数据库,接口响应依然缓慢,而且生产环境会产生许多慢SQL。所以,此方案不采纳。

方案2:利用中间表+缓存

1:分析这四张表发现,最大的表A仅仅起到连接的作用,运营看板计算数据主要来自于B表数据量600w+和C表数据量30w+。因此,新增E表,将所需要的A表与D表的关联数据通过定时任务方式同步到E表,最后E表中数据量为400w+,相比与直接关联A表和D表,数据量整体降低了几百万,后续直接关联查询B表数据量600w+、C表数据量30w+和E表400w计算即可。
2:前端查询接口,先查询缓存,如果查询到则直接返回结果。如果查询不到,再查询缓存并将结果更新到缓存中。

四、总结

采用空间换时间方式,优化了大表关联查询性能,也是一种不错的方案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/89930.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/89930.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/89930.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2025最新版虚幻引擎5(UE5)C++入门教程:前言——你的随身教程和学习笔记

大家好,我是开发游戏的老王,一名高校教师,我主讲游戏开发已有十余年时间,通过我的博客大家应该可以了解我所涉猎的游戏技术范畴非常广泛,除了Unreal,Unity,Godot等主流游戏引擎,还包括Blender、Houdini、3D…

(3)重定向 | 时间相关指令 | 文件查找 | 打包与压缩

Ⅰ . 初始重定向01 输出重定向 >在上一节中我们为了方便讲解 head 和 tail 指令,我们用到了 > 去生成了一千行文本。通过 > 将生成的一千行文本写入到了 large.txt 中……我们现在来正式介绍一下:$ echo "内容" > [目标] 本来应…

DTH11测量温湿度学习(第十一天)

👨‍💻个人主页:开发者-削好皮的Pineapple! 👨‍💻 hello 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 削好皮的Pineapple! 原创 👨‍&#x1f4…

Go语言初识--标识符 可见性

Go语言初识–标识符 可见性 和C语言相似,go语言的基本组成有: 包声明,编写源文件时,必须在非注释的第一行指明这个文件属于哪个包,如package main。引入包,其实就是告诉Go 编译器这个程序需要使用的包&…

Python实例之画小猪佩奇

效果图:python代码以及解释,没有运用模块。 """ 绘制小猪佩奇 """ from turtle import *def nose(x,y):"""画鼻子"""penup()# 将海龟移动到指定的坐标goto(x,y)pendown()# 设置海龟的方向&…

Unity笔记——事件中心

事件中心是什么事件中心是 Unity 游戏开发中常用的架构设计,它基于观察者模式 或 发布-订阅模式,通过委托和事件构建的一种消息管理系统。主要用于降低代码耦合度,实现模块间的松耦合通信的消息处理系统能大幅提升代码的可维护性和扩展性&…

Java: 反射机制的 ParameterizedType(参数化类型)

在 Java 中,ParameterizedType 是 java.lang.reflect 包下的一个接口,属于反射 API 的一部分,主要用于表示参数化类型(即带有类型参数的泛型类型)。它是 Java 反射机制中处理泛型类型信息的关键接口之一。 一、什么是参…

OkHttp 与 Retrofit 完美结合:打造高效的 Android 网络请求

前言在现代 Android 开发中,网络请求是几乎每个应用都必不可少的功能。OkHttp 和 Retrofit 作为当前最流行的网络请求库组合,为开发者提供了简洁高效的解决方案。本文将详细介绍如何将这两者结合使用,充分发挥它们的优势。一、OkHttp 和 Retr…

系统辨识建模

系统辨识建模 一、系统辨识建模的作用 1. 建立真实物理系统的数学模型 2. 为后续控制器/强化学习算法提供仿真环境 3. 提高控制精度和安全性 二、本文的系统辨识是怎么做的 1. 实验采集 2. 数学建模 3. 在控制系统中的作用 三、实际用法流程(简化版) 1. 系统辨识阶段 2. 强化…

Android开发:Java与Kotlin深度对比

1. 语言特性与现代性 Java (特别是 Android 主要使用的 Java 8 及之前版本): 相对冗长: 需要编写更多的样板代码(如 getter/setter、findViewById 的显式类型转换、匿名内部类等)。空指针异常 (NPE): 类型系统默认允许 null&#…

米家打印机驱动:Wi-Fi 无线打印丝滑顺畅不卡顿,从此告别对打印机干瞪眼

各位小米家居控们,你们有没有过这种经历,新买的打印机回家,结果电脑跟它像俩傲娇的小情侣,死活不搭话?急得你想当场表演一个“打印机抱头痛哭”?别急,今天就给你们安利个神队友——米家打印机驱…

日语学习-日语知识点小记-构建基础-JLPT-N3阶段(7):自動詞 & 他動詞

日语学习-日语知识点小记-构建基础-JLPT-N3阶段(7):自動詞 & 他動詞1、前言(1)情况说明(2)工程师的信仰2、知识点(1)自動詞 & 他動…

深入理解设计模式:访问者模式详解

在软件开发中,我们经常会遇到需要对一个复杂对象结构进行操作的情况。随着需求的不断变化,我们可能需要在这个对象结构上添加各种新的操作。如果直接在对象结构中添加这些操作,会导致类的职责过重,且每次添加新操作都需要修改原有…

Linux timerfd 定时器封装

使用 timerfd epoll() 实现&#xff0c;简洁精确。没定义 MU_ERROR 宏的话替换为 printf 即可。mu_timer.h:#ifndef _MU_TIMER_H_ #define _MU_TIMER_H_#ifdef __cplusplus extern "C" { #endif#include <stdint.h> #include <time.h> #include <pth…

【样式效果】Vue3实现仿制iOS按钮动态效果

iOS开关效果定义变量&#xff1a; <style scoped lang"scss">.layout {// 按钮宽度$button-width: 500px;// 按钮高度$button-height: 250px;// 按钮里面圆形直径$circle-diameter: 200px;// 按钮背景与里面圆形间距$button-circle-offset:calc(($button-he…

京东疯狂投资具身智能:众擎机器人+千寻智能+逐际动力 | AI早报

每日分享全球最新AI资讯【应用商业八卦技术】&#xff0c;&#x1f30f;&#xff1a;未来世界2099应用 1、马斯克推出儿童AI"Baby Grok"引热议&#xff1a;安全性能否经受考验&#xff1f; 2、蚂蚁AQ健康应用霸榜苹果商店&#xff0c;或将联手Apple Watch打造智能健康…

Jiasou TideFlow AIGC SEO Agent:全自动外链构建技术重构智能营销新标准

AI时代SEO技术革命&#xff1a;企业如何突破流量增长瓶颈&#xff1f;随着Google算法升级至MUM模型&#xff0c;传统SEO工具已难以应对多模态内容优化需求。在搜索引擎日均处理120亿次查询的生态中&#xff0c;企业官网平均自然流量转化周期长达6-8个月&#xff0c;因此诸如Jia…

Docker-compose:服务编排

Docker-compose 介绍 服务编排:按照一定的业务规则批量管理容器 在微服务架构的应用系统中,一般包含 N 个微服务,且每个微服务一般都会部署多个实例。此时,如果每个微服务都要手动启停,维护的工作量会很大。 要从 Dockerfile build image 或者去 docker hub 拉取 image …

异地服务器备份Mysql数据

前言异地服务器备份Mysql数据即Mysql的server端与备份服务器不是同一个。Mysql服务端安装在192.168.3.36中&#xff0c;现在需要在IP为192.168.209.129的服务器中使用mysqldump命令备份指定数据库数据;192.168.209.129没有装过Mysql客户端;1.安装Mysql客户端不安装Mysql客户端就…

NGINX 高级配置解析:`proxy_request_buffering` 使用详解

在使用 NGINX 作为反向代理服务器时&#xff0c;处理客户端请求体&#xff08;如上传文件或大体积 POST 请求&#xff09;的方式会直接影响应用性能与资源使用。其中&#xff0c;proxy_request_buffering 是一个非常关键但容易被忽略的配置项。 本文将详细介绍该指令的作用、典…