mysqlcpu跑不满

mysqlcpu跑不满,第1张

开APP

Mysql数据库高CPU问题定位和优化 原创

2020-05-30 19:33:37

5点赞

yw804909465

码龄11年

关注

本课程的主旨及目标

•导致mysql数据库CPU高的常见原因

•常见定位问题的方法

•一般定位步骤

•数据库注意事项

导致mysql数据库CPU高的常见原因

占用CPU过高,可以做如下考虑:

1)一般来讲,排除高并发的因素,还是要找到导致你CPU过高的哪几条在执行的SQL,show processlist语句,查找负荷最重的SQL语句,优化该SQL,比如适当建立某字段的索引;

2)打开慢查询日志,将那些执行时间过长且占用资源过多的SQL拿来进行explain分析,导致CPU过高,多数是GroupBy、OrderBy排序问题所导致,然后慢慢进行优化改进。比如优化insert语句、优化group by语句、优化order by语句、优化join语句等等;

3)考虑定时优化文件及索引;

4)定期分析表,使用optimize table;

5)优化数据库对象;

6)考虑是否是锁问题;

7)调整一些MySQL Server参数,比如key_buffer_size、table_cache、innodb_buffer_pool_size、innodb_log_file_size等等;

8)如果数据量过大,可以考虑使用MySQL集群或者搭建高可用环境。

9)可能由于内存(泄露)导致数据库CPU高

10)在多用户高并发的情况下,任何系统都会hold不住的,所以,使用缓存是必须的,使用memcached或者redis缓存都可以;

11)看看tmp_table_size大小是否偏小,如果允许,适当的增大一点;

12)如果max_heap_table_size配置的过小,增大一点;

13)mysql的sql语句睡眠连接超时时间设置问题(wait_timeout)

14)使用show processlist查看mysql连接数,看看是否超过了mysql设置的连接数

一般定位步骤:

   1】首先看看内存 free –m

目前看没有问题,1G的空闲

2】好了,用我们的必杀技,top看看资源消耗

可以看到服务器负载很高,mysql CPU使用已达到接近400%,基本可以看出mysql是可以进行优化的

3

打开SQL Server Profiler 新建跟踪 a.点击新建跟踪,并设置好数据库连接 b.设置跟踪属性,选择模板“Standard” c.切到“事件选择”进行跟踪设置 1) 只保留如下两个事件选项 2) 点击列筛选 3) 进行详细筛选设置 设置CPU时间作为筛选条件,单位毫秒(用于跟踪耗CPU占用较长的查询,可设置为大于等于20000,按CPU内核数×1000,可以跟踪CPU占用100%大于1秒的查询) 点击运行,跟踪语句,定位CPU占用较多的语句 如下图所示,CPU占用2660146毫秒,CPU为24 核,则至少CPU占用100%耗时2660146/24/1000 = 110秒才可以执行好相应的 *** 作 4 根据语句特征,在你的服务器程序中找到相应的功能,作出修正 4.1) 分析查询中需要检索数据量较大的部分,作出简单修正(如注销) 4.2) 更新后重新执行此查询,查看profiler中是否CPU占用消失 4.3) 如果已消失说明问题定位正确,可以优化查询,若CPU占用


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6930806.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-30
下一篇 2023-03-30

发表评论

登录后才能评论

评论列表(0条)

保存