MySQL 8.0资源组有效解决慢SQL引发CPU告警

发布时间:2020-02-21 00:26:29 作者:hcymysql
来源:网络 阅读:484

资源组的作用是资源隔离(你可以理解为开通云主机时勾选的硬件配置),将线上的慢SQL线程id分配给CPU一个核,让它慢慢跑,从而不影响CPU整体性能。

 

创建一个资源组

mysql> create resource group slowsql_rg type=user vcpu=3 
thread_priority=19 enable;

slowsql_rg为资源组名字

type=user 来源是用户端的慢SQL

vcpu=3 给它分配到哪个CPU核上(你可以用cat /proc/cpuinfo  | grep processor查看CPU有多少核)

thread_priority为优先级别,范围是01919是最低优先级0是最高优先级


查看资源组信息

mysql> select * from information_schema.resource_groups;


查找慢SQL的线程ID

SELECT THREAD_ID,PROCESSLIST_INFO,RESOURCE_GROUP,PROCESSLIST_TIME FROM 
performance_schema.threads WHERE PROCESSLIST_INFO REGEXP 
'SELECT|INSERT|UPDATE|DELETE|ALTER' AND PROCESSLIST_TIME > 10;


THREAD_ID取出来的值,放入资源组里做限制

set resource group slowsql_rg for 379;


比如你想放宽的限制,也可以更改

ALTER RESOURCE GROUP slowsql_rg VCPU = 3 THREAD_PRIORITY = 0;


关闭资源组,解除限制

ALTER RESOURCE GROUP slowsql_rg DISABLE FORCE;




推荐阅读:
  1. MySQL8.0的特点资源管理详解
  2. MySQL8.0 GA版本的新特性有哪些

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql8 资源组 慢sql

上一篇:07-09 面向过程与函数式

下一篇:BC网站专业制作一条龙

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》