亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解MySQL資源組的使用方法

 更新時(shí)間:2024年07月29日 10:24:10   作者:icysmile131  
MySQL支持創(chuàng)建和管理資源組,并允許將服務(wù)器內(nèi)運(yùn)行的線程分配給特定的組,本文主要介紹了詳解MySQL資源組的使用方法,具有一定的參考價(jià)值,感興趣的可以了解一下

MySQL支持創(chuàng)建和管理資源組,并允許將服務(wù)器內(nèi)運(yùn)行的線程分配給特定的組,以便線程根據(jù)組可用的資源執(zhí)行。組屬性允許控制其資源,以啟用或限制組中線程的資源消耗。DBA可以針對(duì)不同的工作負(fù)載適當(dāng)?shù)匦薷倪@些屬性。

目前,CPU時(shí)間是一種可管理的資源,以“虛擬CPU”的概念表示,該概念包括CPU核心、超線程、硬件線程等。服務(wù)器在啟動(dòng)時(shí)確定有多少虛擬CPU可用,具有適當(dāng)權(quán)限的數(shù)據(jù)庫(kù)管理員可以將這些CPU與資源組相關(guān)聯(lián),并將線程分配給組。

例如,為了管理不需要以高優(yōu)先級(jí)執(zhí)行的批處理作業(yè)的執(zhí)行,DBA可以創(chuàng)建一個(gè)批處理資源組,并根據(jù)服務(wù)器的繁忙程度調(diào)整其優(yōu)先級(jí)??梢詥⒂没蚪媒M來控制線程是否可分配給它們。

以下部分描述了MySQL中資源組使用的各個(gè)方面:

1 資源組元素

這些功能為MySQL中的資源組管理提供了SQL接口:

  • SQL語句允許創(chuàng)建、更改和刪除資源組,并允許將線程分配給資源組。優(yōu)化器提示允許將單個(gè)語句分配給資源組。
  • 資源組權(quán)限提供對(duì)哪些用戶可以執(zhí)行資源組操作的控制。
  • 信息架構(gòu)RESOURCE_GROUPS表顯示有關(guān)資源組定義的信息,性能架構(gòu)線程表顯示每個(gè)線程的資源組分配。
  • 狀態(tài)變量提供每個(gè)管理SQL語句的執(zhí)行計(jì)數(shù)。

2 資源組屬性

資源組具有定義該組的屬性。所有屬性都可以在組創(chuàng)建時(shí)設(shè)置。某些屬性在創(chuàng)建時(shí)是固定的;其他可以在此后的任何時(shí)間進(jìn)行修改。

這些屬性是在創(chuàng)建資源組時(shí)定義的,不能修改:

  • 每個(gè)組都有一個(gè)名稱。資源組名稱是類似于表和列名的標(biāo)識(shí)符,除非它們包含特殊字符或是保留字,否則不需要在SQL語句中引用。組名不區(qū)分大小寫,最長(zhǎng)可達(dá)64個(gè)字符。
  • 每個(gè)組都有一個(gè)類型,即SYSTEM或USER。資源組類型影響可分配給該組的優(yōu)先級(jí)值的范圍,如后所述。該屬性以及允許優(yōu)先級(jí)的差異使系統(tǒng)線程能夠被識(shí)別,從而保護(hù)它們免受用戶線程對(duì)CPU資源的爭(zhēng)用。

系統(tǒng)和用戶線程對(duì)應(yīng)于性能模式線程表中列出的后臺(tái)和前臺(tái)線程。

這些屬性是在資源組創(chuàng)建時(shí)定義的,此后可以隨時(shí)修改:

  • CPU相關(guān)性是資源組可以使用的一組虛擬CPU。親和性可以是可用CPU的任何非空子集。如果一個(gè)組沒有關(guān)聯(lián),它可以使用所有可用的CPU。
  • 線程優(yōu)先級(jí)是分配給資源組的線程的執(zhí)行優(yōu)先級(jí)。優(yōu)先級(jí)值的范圍從-20(最高優(yōu)先級(jí))到19(最低優(yōu)先級(jí))。系統(tǒng)組和用戶組的默認(rèn)優(yōu)先級(jí)均為0。

允許系統(tǒng)組的優(yōu)先級(jí)高于用戶組,確保用戶線程的優(yōu)先級(jí)永遠(yuǎn)不會(huì)高于系統(tǒng)線程:

(1)對(duì)于系統(tǒng)資源組,允許的優(yōu)先級(jí)范圍為-20到0。

(2)對(duì)于用戶資源組,允許的優(yōu)先級(jí)范圍為0到19。

  • 每個(gè)組都可以啟用或禁用,使管理員能夠控制線程分配。線程只能分配給已啟用的組。

3 資源組管理

默認(rèn)情況下,有一個(gè)系統(tǒng)組和一個(gè)用戶組,分別命名為SYS_default和USR_default。不能刪除這些默認(rèn)組,也不能修改它們的屬性。每個(gè)默認(rèn)組都沒有CPU相關(guān)性,優(yōu)先級(jí)為0。

新創(chuàng)建的系統(tǒng)線程和用戶線程分別分配給SYS_default和USR_default組。

對(duì)于用戶定義的資源組,所有屬性都在組創(chuàng)建時(shí)指定。創(chuàng)建組后,可以修改其屬性,但名稱和類型屬性除外。

要?jiǎng)?chuàng)建和管理用戶定義的資源組,請(qǐng)使用以下SQL語句:

  • CREATE RESOURCE GROUP創(chuàng)建一個(gè)新組。
  • ALTER RESOURCE GROUP修改現(xiàn)有組。
  • DROP RESOURCE GROUP刪除現(xiàn)有組。

這些語句需要RESOURCE_GROUP_ADMIN權(quán)限。

要管理資源組分配,請(qǐng)使用以下功能:

  • SET RESOURCE GROUP將線程分配給一個(gè)組。
  • RESOURCE_GROUP優(yōu)化器提示將單個(gè)語句分配給一個(gè)組。

這些操作需要RESOURCE_GROUP_ADMIN或RESOURCE-GROUP_USER權(quán)限。

資源組定義存儲(chǔ)在Resource_groups數(shù)據(jù)字典表中,以便組在服務(wù)器重新啟動(dòng)時(shí)保持不變。因?yàn)閞esource_groups是數(shù)據(jù)字典的一部分,所以用戶無法直接訪問它。使用信息模式Resource_GROUPS表可以獲得資源組信息,該表被實(shí)現(xiàn)為數(shù)據(jù)字典表上的視圖。

最初,RESOURCE_GROUPS表中有以下行描述默認(rèn)組:

mysql> SELECT * FROM INFORMATION_SCHEMA.RESOURCE_GROUPS\G
*************************** 1. row ***************************
   RESOURCE_GROUP_NAME: USR_default
   RESOURCE_GROUP_TYPE: USER
RESOURCE_GROUP_ENABLED: 1
              VCPU_IDS: 0-3
       THREAD_PRIORITY: 0
*************************** 2. row ***************************
   RESOURCE_GROUP_NAME: SYS_default
   RESOURCE_GROUP_TYPE: SYSTEM
RESOURCE_GROUP_ENABLED: 1
              VCPU_IDS: 0-3
       THREAD_PRIORITY: 0

THREAD_PRIORITY值為0,表示默認(rèn)優(yōu)先級(jí)。VCPU_IDS值顯示了包括所有可用CPU的范圍。對(duì)于默認(rèn)組,顯示的值因MySQL服務(wù)器運(yùn)行的系統(tǒng)而異。

前面的討論提到了一個(gè)場(chǎng)景,該場(chǎng)景涉及一個(gè)名為Batch的資源組來管理不需要高優(yōu)先級(jí)執(zhí)行的批處理作業(yè)的執(zhí)行。要?jiǎng)?chuàng)建這樣一個(gè)組,請(qǐng)使用類似以下的語句:

CREATE RESOURCE GROUP Batch
  TYPE = USER
  VCPU = 2-3            -- assumes a system with at least 4 CPUs
  THREAD_PRIORITY = 10;

要驗(yàn)證資源組是否按預(yù)期創(chuàng)建,請(qǐng)檢查resource_GROUPS表:

mysql> SELECT * FROM INFORMATION_SCHEMA.RESOURCE_GROUPS
       WHERE RESOURCE_GROUP_NAME = 'Batch'\G
*************************** 1. row ***************************
   RESOURCE_GROUP_NAME: Batch
   RESOURCE_GROUP_TYPE: USER
RESOURCE_GROUP_ENABLED: 1
              VCPU_IDS: 2-3
       THREAD_PRIORITY: 10

如果THREAD_PRIORITY值為0而不是10,請(qǐng)檢查您的平臺(tái)或系統(tǒng)配置是否限制了資源組功能;請(qǐng)參閱資源組限制。

要將線程分配給批處理組,請(qǐng)執(zhí)行以下操作:

SET RESOURCE GROUP Batch FOR thread_id;

此后,命名線程中的語句將使用批處理組資源執(zhí)行。

如果會(huì)話自己的當(dāng)前線程應(yīng)該在Batch組中,請(qǐng)?jiān)跁?huì)話中執(zhí)行以下語句:

SET RESOURCE GROUP Batch;

此后,會(huì)話中的語句將使用批處理組資源執(zhí)行。

要使用Batch組執(zhí)行單個(gè)語句,請(qǐng)使用RESOURCE_group優(yōu)化器提示:

INSERT /*+ RESOURCE_GROUP(Batch) */ INTO t2 VALUES(2);

分配給批處理組的線程使用其資源執(zhí)行,可以根據(jù)需要進(jìn)行修改:

  • 當(dāng)系統(tǒng)負(fù)載很高時(shí),減少分配給該組的CPU數(shù)量,降低其優(yōu)先級(jí),或者(如圖所示)兩者兼有:
ALTER RESOURCE GROUP Batch
  VCPU = 3
  THREAD_PRIORITY = 19;
  • 在系統(tǒng)負(fù)載較輕的情況下,增加分配給組的CPU數(shù)量,提高其優(yōu)先級(jí),或(如圖所示)兩者兼有:
ALTER RESOURCE GROUP Batch
  VCPU = 0-3
  THREAD_PRIORITY = 0;

4 資源組復(fù)制

資源組管理是發(fā)生該管理的服務(wù)器的本地管理。資源組SQL語句和對(duì)Resource_groups數(shù)據(jù)字典表的修改不會(huì)寫入二進(jìn)制日志,也不會(huì)被復(fù)制。

5 資源組限制

在某些平臺(tái)或MySQL服務(wù)器配置上,資源組不可用或有限制:

如果安裝了線程池插件,則資源組不可用。

資源組在macOS上不可用,macOS不提供將CPU綁定到線程的API。

在FreeBSD和Solaris上,資源組線程優(yōu)先級(jí)被忽略。(實(shí)際上,所有線程都以優(yōu)先級(jí)0運(yùn)行。)嘗試更改優(yōu)先級(jí)會(huì)導(dǎo)致警告:

mysql> ALTER RESOURCE GROUP abc THREAD_PRIORITY = 10;
Query OK, 0 rows affected, 1 warning (0.18 sec)

mysql> SHOW WARNINGS;
+---------+------+-------------------------------------------------------------+
| Level   | Code | Message                                                     |
+---------+------+-------------------------------------------------------------+
| Warning | 4560 | Attribute thread_priority is ignored (using default value). |
+---------+------+-------------------------------------------------------------+
  • 在Linux上,除非設(shè)置了CAP_SYS_NICE功能,否則資源組線程優(yōu)先級(jí)將被忽略。向進(jìn)程授予CAP_SYS_NICE功能將啟用一系列特權(quán);咨詢http://man7.org/linux/man-pages/man7/capabilities.7.html查看完整列表。啟用此功能時(shí)請(qǐng)小心。

在使用systemd和內(nèi)核支持Ambient Capabilities(Linux 4.3或更新版本)的Linux平臺(tái)上,建議啟用CAP_SYS_NICE功能的方法是修改MySQL服務(wù)文件并保持mysqld二進(jìn)制文件不變。要調(diào)整MySQL的服務(wù)文件,請(qǐng)使用以下過程:

(1)為您的平臺(tái)運(yùn)行適當(dāng)?shù)拿睿?/h3>

a, Oracle Linux、Red Hat和Fedora系統(tǒng):

$> sudo systemctl edit mysqld

b. SUSE、Ubuntu和Debian系統(tǒng):

$> sudo systemctl edit mysql

(2)使用編輯器,將以下文本添加到服務(wù)文件中:

[Service]
AmbientCapabilities=CAP_SYS_NICE

(3)重新啟動(dòng)MySQL服務(wù)

如果不能像剛才描述的那樣啟用CAP_SYS_NICE功能,可以使用setcap命令手動(dòng)設(shè)置它,指定mysqld可執(zhí)行文件的路徑名(這需要sudo訪問權(quán)限)。您可以使用getcap檢查功能。例如:

$> sudo setcap cap_sys_nice+ep /path/to/mysqld
$> getcap /path/to/mysqld
/path/to/mysqld = cap_sys_nice+ep

作為一項(xiàng)安全措施,將mysqld二進(jìn)制文件的執(zhí)行限制為root用戶和具有mysql組成員身份的用戶:

$> sudo chown root:mysql /path/to/mysqld
$> sudo chmod 0750 /path/to/mysqld

如果需要手動(dòng)使用setcap,則必須在每次重新安裝后進(jìn)行。

在Windows上,線程以五個(gè)線程優(yōu)先級(jí)之一運(yùn)行。資源組線程優(yōu)先級(jí)范圍-20到19映射到下表所示的級(jí)別。

到此這篇關(guān)于詳解MySQL資源組的使用方法的文章就介紹到這了,更多相關(guān)MySQL資源組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • MySQL中索引失效的常見場(chǎng)景與規(guī)避方法

    MySQL中索引失效的常見場(chǎng)景與規(guī)避方法

    這篇文章主要給大家介紹了關(guān)于MySQL中索引失效的常見場(chǎng)景與規(guī)避的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • mysql 使用B+樹索引有哪些優(yōu)勢(shì)

    mysql 使用B+樹索引有哪些優(yōu)勢(shì)

    這篇文章主要介紹了mysql 使用B+樹索引有哪些優(yōu)勢(shì),幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2021-01-01
  • MySQL字符之char、varchar類型簡(jiǎn)析

    MySQL字符之char、varchar類型簡(jiǎn)析

    varchar和char是MySQL中的兩種數(shù)據(jù)類型,都是用來存儲(chǔ)字符串的,下面這篇文章主要給大家介紹了關(guān)于MySQL字符之char、varchar類型的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解

    mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解

    這篇文章主要介紹了mysql 一次向表中插入多條數(shù)據(jù)實(shí)例講解的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • MySQL視圖中如何使用IF和CASE語句

    MySQL視圖中如何使用IF和CASE語句

    這篇文章主要介紹了MySQL視圖中如何使用IF和CASE語句問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 最新評(píng)論