功夫码

mysql占用了90%以上的cpu问题排查

晓峰 时间:2019-08-05 08:07:56 阅读:9

1 在linux下用,使用top命令看到的情况如下:

可以看到服务器负载很高,,mysql CPU使用已达到接近400%(因为是四核,所以会有超过100%的情况)。

2  在服务器上执行mysql -u root -p之后,输入show full processlist; 可以看到正在执行的语句。

可以看到是上边的SQL语句执行耗费了较长时间。

查看这几张表能添加的索引都已添加。

解决方法1:

调整参数 tmp_table_size、max_heap_table_size

查看当前的tmp_table_size

SHOW VARIABLES like 'tmp_table_size';

查课当前max_heap_table_size

SHOW VARIABLES LIKE 'max_heap_table_size%';

1.1 动态设置这俩个值

SET GLOBAL tmp_table_size=629145600;
SET GLOBAL max_heap_table_size=1073741824;

1,2 通过修改my.cnf修改这俩配置;

vi /etc/my.cnf 

[mysqld] 

max_heap_table_size = 200M 

tmp_table_size = 200M


这两个参数是mysql对临时表的大小控制 

其中tmp_table_size 控制内存临时表的最大值,超过限值后就往硬盘写,写的位置由变量 tmpdir 决定 

max_heap_table_size 用户可以创建的内存表(memory table)的大小.这个值用来计算内存表的最大行数值。


解决方案2 

就是优化上边那些sql语句进行再次优化,推荐此方法。


本文来源:功夫码(gongfuma.com)

声明:本文系功夫码原创稿件,版权属[功夫码 gongfuma.com]所有,未经授权不得转载,已经协议授权的媒体下载使用时须注明"稿件来源:功夫码",违者将依法追究责任。

相关文章

回到顶部