mysql进程占服务器cpu100%的解决方法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zhou_fan_xi/article/details/84965836

一、使用top命令看到的情况如下:

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


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

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

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

调整参数 tmp_table_size、max_heap_table_size

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

tmp_table_size 控制内存临时表的最大值,超过限值后就往硬盘写,写的位置由变量 tmpdir 决定 
max_heap_table_size 用户可以创建的内存表(memory table)的大小.这个值用来计算内存表的最大行数值。


vi /etc/my.cnf 
[mysqld] 
max_heap_table_size = 200M 
tmp_table_size = 200M

然后重启 MySQL 服务。CPU 占用有所下降

猜你喜欢

转载自blog.csdn.net/zhou_fan_xi/article/details/84965836
今日推荐