CREATE WORKLOAD GROUP (Transact-SQL)
建立資源管理員工作負載群組,並將工作負載群組與資源管理員資源集區產生關聯。 並非每個 Microsoft SQL Server 版本中都無法使用資源管理員。 如需 SQL Server 版本所支援的功能清單,請參閱<SQL Server 2012 版本支援的功能>。
語法
CREATE WORKLOAD GROUP group_name
[ WITH
( [ IMPORTANCE = { LOW | MEDIUM | HIGH } ]
[ [ , ] REQUEST_MAX_MEMORY_GRANT_PERCENT = value ]
[ [ , ] REQUEST_MAX_CPU_TIME_SEC = value ]
[ [ , ] REQUEST_MEMORY_GRANT_TIMEOUT_SEC = value ]
[ [ , ] MAX_DOP = value ]
[ [ , ] GROUP_MAX_REQUESTS = value ] )
]
[ USING { pool_name | "default" } ]
[ ; ]
引數
group_name
這是工作負載群組的使用者定義名稱。 group_name 是英數字元,最多可有 128 個字元,而且在 SQL Server 執行個體內必須是唯一的,並須符合識別碼的規則。IMPORTANCE = { LOW | MEDIUM | HIGH }
指定要求在工作負載群組中的相對重要性。 下列任一個為其重要性,其中 MEDIUM 為預設值:LOW
MEDIUM
HIGH
[!附註]
每個重要性設定在內部都會儲存為計算所使用的數字。
IMPORTANCE 的資源集區範圍為本機;相同資源集區內部不同重要性的工作負載群組會彼此影響,但不會影響另一個資源集區中的工作負載群組。
REQUEST_MAX_MEMORY_GRANT_PERCENT =value
指定單一要求可由集區中獲取的記憶體最大數量。 這個百分比相對於 MAX_MEMORY_PERCENT 所指定的資源集區大小。[!附註]
指定的數量僅參考查詢執行授與記憶體。
value 必須為 0 或正整數。 允許的 value 範圍從 0 至 100。 value 的預設值為 25。
請注意下列事項:
將 value 設定為 0 會避免執行在使用者定義之工作負載群組內具有 SORT 和 HASH JOIN 作業的查詢。
我們不建議您將 value 設定為大於 70 的值,因為如果其他並行查詢正在執行,伺服器可能無法將足夠的記憶體擱置在一旁。 最後,這可能會導致查詢逾時錯誤 8645。
[!附註]
如果查詢記憶體需求超過這個參數所指定的限制,伺服器會執行以下作業:
如果是使用者定義的工作負載群組,伺服器會嘗試減少查詢的平行處理原則程度,直到記憶體需求低於此限制,或是直到平行處理原則程度等於 1 為止。 如果查詢記憶體需求仍然大於此限制,將會發生錯誤 8657。
如果是內部和預設的工作負載群組,伺服器會允許查詢取得所需的記憶體。
請注意,如果伺服器沒有足夠的實體記憶體,這兩種情況都會受限於逾時錯誤 8645。
REQUEST_MAX_CPU_TIME_SEC =value
指定要求可以使用的最大 CPU 時間量 (以秒為單位)。 value 必須為 0 或正整數。 value 的預設值為 0,這代表沒有限制。[!附註]
資源管理員不會在超過最大時間時阻止要求繼續執行。 不過,系統將會產生某個事件。 如需詳細資訊,請參閱<CPU Threshold Exceeded 事件類別>。
REQUEST_MEMORY_GRANT_TIMEOUT_SEC =value
指定查詢能夠等待記憶體授權 (工作緩衝區記憶體) 變成可用的最大時間 (以秒為單位)。[!附註]
到達記憶體授權的逾時值時,查詢不一定會失敗。 只有當有太多並行的查詢正在執行時,查詢才會失敗。 否則,查詢可能只會得到最小的記憶體授權,導致查詢效能降低。
value 必須為 0 或正整數。 value 的預設值 0 會根據查詢成本使用內部計算來判斷最大時間。
MAX_DOP =value
為平行要求指定平行處理原則的最大程度 (DOP)。 value 必須為 0 或正整數。 允許的 value 範圍從 0 至 64。 value 的預設值 0 會使用全域設定。 MAX_DOP 會以下列方式處理:當做查詢提示的 MAX_DOP 會維持有效,直到它超過工作負載群組 MAX_DOP 為止。 從 SQL Server 2008 開始,如果 MAXDOP 查詢提示值超過使用資源管理員所設定的值,Database Engine 就會使用資源管理員 MAXDOP 值。
做為查詢提示的 MAX_DOP 會固定覆寫 sp_configure 'max degree of parallelism'。
工作負載群組 MAX_DOP 會覆寫 sp_configure 'max degree of parallelism'。
如果查詢在編譯時間標示為序列,不論工作負載群組或 sp_configure 設定為何,都無法在執行階段將該查詢變更回平行。
DOP 經過設定後,在授與記憶體不足的壓力下,僅能將其降低。 在授與記憶體佇列中等候時,看不到工作負載群組的重新組態。
GROUP_MAX_REQUESTS =value
指定在工作負載群組中可允許執行的最大同時要求數。 value 必須為 0 或正整數。 value 的預設值 0 允許無限制的要求。 達到最大並行要求時,該群組中的使用者可以登入,但是會處於等候狀態,直到並行要求低於指定的值為止。USING { pool_name | "default" }
將工作負載群組與 pool_name 所識別之使用者定義資源集區產生關聯。 這樣會將工作負載群組實際放到資源集區中。 如果未提供 pool_name 或未使用 USING 引數,工作負載群組會放入預先定義的資源管理員預設集區。"default" 是保留字,而且當搭配 USING 使用時,必須加上引號 ("") 或方括號 ([])。
[!附註]
預先定義的工作負載群組和資源集區都會使用小寫名稱,例如 "default"。 如果是使用區分大小寫之定序的伺服器,則應該將此列入考量。 具有不區分大小寫之定序 (如 SQL_Latin1_General_CP1_CI_AS) 的伺服器會將 "default" 和 "Default" 視為相同。
備註
REQUEST_MEMORY_GRANT_PERCENT:允許建立索引即可使用比一開始授與之記憶體更多的工作空間記憶體來改善效能。 在 SQL Server 2012 中,資源管理員支援這種特殊的處理。 不過,初始授與和任何額外的記憶體授與都受到資源集區和工作負載群組設定的限制。
資料分割資料表上的索引建立
非對齊式資料分割資料表上之索引建立所耗用的記憶體,與相關的資料分割數目成正比。 如果所需的總記憶體超出資源管理員工作負載群組設定所設的每個查詢限制 (REQUEST_MAX_MEMORY_GRANT_PERCENT),這個索引建立動作就可能無法執行。 由於 "default" 工作負載群組允許查詢超過每個查詢限制,而且具有所需的記憶體下限,因此使用者或許能夠在 "default" 工作負載群組中執行相同的索引建立動作,但前提是 "default" 資源集區有設定足夠的總記憶體來執行這類查詢。
權限
需要 CONTROL SERVER 權限。
範例
下列範例會顯示如何建立名稱為 newReports 的工作負載群組。 它會使用資源管理員預設值,而且位於資源管理員預設集區中。 此範例會指定 default 集區,但這不是必要的。
CREATE WORKLOAD GROUP newReports
USING "default" ;
GO
請參閱
參考
ALTER WORKLOAD GROUP (Transact-SQL)
DROP WORKLOAD GROUP (Transact-SQL)
CREATE RESOURCE POOL (Transact-SQL)
ALTER RESOURCE POOL (Transact-SQL)