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

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

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

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

fe15ca8747bc4bfd372b38514a75aa51.png

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

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

解决方法1:

调整参数 tmp_table_size、max_heap_table_size

查看当前的tmp_table_sizeSHOW VARIABLES like 'tmp_table_size';

查课当前max_heap_table_sizeSHOW 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语句进行再次优化,推荐此方法。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值