一、使用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 占用有所下降