博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL8.0: 通过Resource Group来控制线程计算资源
阅读量:6273 次
发布时间:2019-06-22

本文共 3317 字,大约阅读时间需要 11 分钟。

MySQL8.0增加了一个新功能resource group, 可以对不同的用户进行资源控制,例如对用户线程和后台系统线程给予不同的CPU优先级。

用户可以通过SQL接口创建不同的分组,这些分组可以作为sql的hit,也可以动态的绑定过去。本文主要简单介绍下用法,至于底层如何实现的,其实比较简单:创建的分组被存储到系统表中;在linux系统底层通过CPU_SET来绑定CPU,通过setpriority来设置线程的nice值

相关worklog:

[WL#9467: Resource Groups(

创建resource group

首先系统自带两个resource group并且不可被修改

root@(none) 05:54:22>SELECT * FROM INFORMATION_SCHEMA.RESOURCE_GROUPS\G*************************** 1. row ***************************RESOURCE_GROUP_NAME: USR_defaultRESOURCE_GROUP_TYPE: USERRESOURCE_GROUP_ENABLED: 1VCPU_IDS: 0-63THREAD_PRIORITY: 0*************************** 2. row ***************************RESOURCE_GROUP_NAME: SYS_defaultRESOURCE_GROUP_TYPE: SYSTEMRESOURCE_GROUP_ENABLED: 1VCPU_IDS: 0-63THREAD_PRIORITY: 02 rows in set (0.00 sec)

如果你想设置thread priority,可能需要使用超级账户来启动Mysqld,这是系统限制,如果以非super账户启动,只能降低而不能提升优先级。在非super启动时,thread_priority会被忽略掉并报一个warning出来。

对于类型为system的系统后台线程,cpu priority只能从-20 ~0,而普通user线程,则在0~19之间,这样就保证了系统线程的优先级肯定比用户线程高。

如果设置不在范围内,就会报错

root@(none) 10:27:09>CREATE RESOURCE GROUP test_user_rg   TYPE = USER   VCPU = 0-32,48-63   THREAD_PRIORITY = -10;ERROR 3654 (HY000): Invalid thread priority value -10 for User resource group test_user_rg. Allowed range is [0, 19].

我们尝试为user类线程创建一个resource group,使用0-32, 48-63号cpu, 线程优先级为10

root@(none) 10:27:14>CREATE RESOURCE GROUP test_user_rg   TYPE = USER   VCPU = 0-32,48-63   THREAD_PRIORITY = 10;Query OK, 0 rows affected (0.01 sec)root@(none) 10:55:19>SELECT * FROM INFORMATION_SCHEMA.RESOURCE_GROUPS WHERE RESOURCE_GROUP_NAME = 'test_user_rg'\G*************************** 1. row ***************************   RESOURCE_GROUP_NAME: test_user_rg   RESOURCE_GROUP_TYPE: USERRESOURCE_GROUP_ENABLED: 1              VCPU_IDS: 0-32,48-63       THREAD_PRIORITY: 101 row in set (0.00 sec)

CREATE/DELETE/ALTER RESOURCE GROUP都需要RESOURCE_GROUP_ADMIN权限,具体的语法见

使用resource group

创建好后,我们该如何使用resource group呢,主要有两种方式,一种是SET RESOURCE GROUP, 一种是通过SQL HINT的方式,以下是简单的测试:

设置当前session:

root@(none) 11:01:08>SET RESOURCE GROUP test_user_rg;Query OK, 0 rows affected (0.00 sec)

也可以指定hint的方式来设置:

root@sb1 11:07:53>select /* + RESOURCE_GROUP(test_user_rg) */ * from sbtest1 where id <10;

还可以通过thread id来设置其他运行中的session,注意这里的thread id不是show processlist看到的id,而是通过performance_schema.threads表看到的id

xx@performance_schema 11:30:21>SELECT THREAD_ID, TYPE FROM performance_schema.threads WHERE PROCESSLIST_ID = 26\G*************************** 1. row ***************************THREAD_ID: 71     TYPE: FOREGROUND1 row in set (0.00 sec)xx@performance_schema 11:30:43>SET RESOURCE GROUP test_user_rg for 71;Query OK, 0 rows affected (0.00 sec)​

如果你想对InnoDB的后台线程来进行设置呢 ? 可以去查看performance_schema.threads表,例如我们对page cleaner进行优先级设置:

xx@performance_schema 11:19:43>CREATE RESOURCE GROUP test_system_rg   TYPE = SYSTEM   VCPU = 49   THREAD_PRIORITY = -10;Query OK, 0 rows affected (0.00 sec)xx@performance_schema 11:24:11>SELECT THREAD_ID, TYPE FROM performance_schema.threads WHERE NAME LIKE '%page_flush_coor%'\G*************************** 1. row ***************************THREAD_ID: 13     TYPE: BACKGROUND1 row in set (0.00 sec)xx@performance_schema 11:24:07>SET RESOURCE GROUP test_system_rg for 13;Query OK, 0 rows affected (0.00 sec)

可以看到,通过resource group,我们可以为任意的线程指定不同的计算资源。在未来我们甚至可以对这一功能进行扩展,例如某个线程的最大iops,读入数据占用buffer pool的百分比,或者对运维程序指定独立的cpu,避免干扰到正常的业务负载等等,还是有不少的想象空间的。

转载地址:http://hnvpa.baihongyu.com/

你可能感兴趣的文章
At.js – 用于 Web 应用程序的自动完成库
查看>>
[Android Pro] Android权限设置android.permission完整列表
查看>>
如何对抗硬件断点--- 调试寄存器
查看>>
mybatis学习
查看>>
从不同层面看cocos2d-x
查看>>
Struts2技术详解
查看>>
MFC应用程序向导生成的文件
查看>>
Oracle体系结构之oracle密码文件管理
查看>>
【leetcode】Remove Element (easy)
查看>>
mysql多表查询及其 group by 组内排序
查看>>
alsa的snd_pcm_readi()函数和snd_pcm_writei()
查看>>
Android学习网站推荐(转)
查看>>
嵌入式根文件系统的移植和制作详解
查看>>
MEF部件的生命周期(PartCreationPolicy)
查看>>
LCD的接口类型详解
查看>>
nginx 基础文档
查看>>
LintCode: Unique Characters
查看>>
Jackson序列化和反序列化Json数据完整示例
查看>>
.net 中的DllImport
查看>>
nyoj 517 最小公倍数 【java睑板】
查看>>