千家信息网

MySQL引起的CPU消耗过大该如何优化

发表于:2024-11-22 作者:千家信息网编辑
千家信息网最后更新 2024年11月22日,本篇文章给大家分享的是有关MySQL引起的CPU消耗过大该如何优化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。谁在消耗cpu?用户+系
千家信息网最后更新 2024年11月22日MySQL引起的CPU消耗过大该如何优化

本篇文章给大家分享的是有关MySQL引起的CPU消耗过大该如何优化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

谁在消耗cpu?

用户+系统+IO等待+软硬中断+空闲

祸首是谁?

用户

用户空间CPU消耗,各种逻辑运算

正在进行大量tps

函数/排序/类型转化/逻辑IO访问…

用户空间消耗大量cpu,产生的系统调用是什么?那些函数使用了cpu周期?

IO等待

等待IO请求的完成

此时CPU实际上空闲

如vmstat中的wa 很高。但IO等待增加,wa也不一定会上升(请求I/O后等待响应,但进程从核上移开了)

产生影响

用户和IO等待消耗了大部分cpu

  • 吞吐量下降(tps)

  • 查询响应时间增加

  • 慢查询数增加

  • 对mysql的并发陡增,也会产生上诉影响

如何减少CPU消耗?

减少等待

减少IO量

SQL/index,使用合适的索引减少扫描的行数(需平衡索引的正收益和维护开销,空间换时间)

提升IO处理能力

加cache/加磁盘/SSD

减少计算

减少逻辑运算量

  • 避免使用函数,将运算转移至易扩展的应用服务器中

如substr等字符运算,dateadd/datesub等日期运算,abs等数学函数

  • 减少排序,利用索引取得有序数据或避免不必要排序

如union all代替 union,order by 索引字段等

  • 禁止类型转换,使用合适类型并保证传入参数类型与数据库字段类型绝对一致

如数字用tiny/int/bigint等,必需转换的在传入数据库之前在应用中转好

  • 简单类型,尽量避免复杂类型,降低由于复杂类型带来的附加运算。更小的数据类型占用更少的磁盘、内存、cpu缓存和cpu周期

  • ….

减少逻辑IO量

index,优化索引,减少不必要的表扫描

如增加索引,调整组合索引字段顺序,去除选择性很差的索引字段等等

  • table,合理拆分,适度冗余

如将很少使用的大字段拆分到独立表,非常频繁的小字段冗余到"引用表"

  • SQL,调整SQL写法,充分利用现有索引,避免不必要的扫描,排序及其他操作

如减少复杂join,减少order by,尽量union all,避免子查询等

  • 数据类型,够用就好,减少不必要使用大字段

如tinyint够用就别总是int,int够用也别老bigint,date够用也别总是timestamp

  • ….

减少query请求量(非数据库本身)

  • 适当缓存,降低缓存数据粒度,对静态并被频繁请求的数据进行适当的缓存

如用户信息,商品信息等

  • 优化实现,尽量去除不必要的重复请求

如禁止同一页面多次重复请求相同数据的问题,通过跨页面参数传递减少访问等

  • 合理需求,评估需求产出比,对产出比极端底下的需求合理去除

  • ….

升级cpu

若经过减少计算和减少等待后还不能满足需求,cpu利用率还高T_T

是时候拿出最后的杀手锏了,升级cpu,是选择更快的cpu还是更多的cpu了?

  • 低延迟(快速响应),需要更快的cpu(每个查询只能使用一个cpu)

  • 高吞吐,同时运行很多查询语句,能从多个cpu处理查询中收益

以上就是MySQL引起的CPU消耗过大该如何优化,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。

类型 数据 索引 消耗 字段 用户 查询 运算 函数 够用 缓存 逻辑 需求 排序 复杂 数据库 更多 空间 合适 适当 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 直销网络技术是什么 成都计算机应用软件开发靠谱吗 win11对软件开发影响 vb连接sql数据库报错 服务器属于软件系统还是硬件系统 闻喜恒峰腾网络技术有限公司 如何在网络安全模式玩游戏 服务器远程虚拟机usb读取 手机总是显示服务器出现错误 数据库应用实训 国内网络服务器价格 景区管理平台软件开发费用 北京服务器虚拟化厂商哪家好 如何对服务器硬盘加密 魔兽世界四区服务器 网络安全指数是什么意思 济南果蔬软件开发 软件开发项目经理月薪是多少 东营微信小程序软件开发推荐 数据库基础sql知识面试题二 数据库安全应用指南 网络安全宣传视频喀什 数据库服务器有哪些服务器 证书服务器地址 网络安全宣传周作为每年 vm虚拟机web服务器搭建 吉林省网络安全指挥中心 简述软件开发模型各优缺点 中国大学生在线网络安全答题 后端数据库技术
0