作者:陈炘宇_573 | 来源:互联网 | 2024-11-07 20:38
资源管理器的基础架构包括三个核心组件:1)资源池,用于将CPU和内存等资源分配给不同的容器;2)负载组,负责承载任务并将其分配到相应的资源池;3)分类函数,用于将不同的会话映射到合适的负载组。该系统提供了两种主要的资源管理策略。
资源调控器分为三部分:
1:资源池,将资源CPU/MEMORY划分到不同的载体上
2:负载组,承载负载并将负载映射到不同的资源池
3:
分类函数,将不同回话映射到不同的负载组
08提供两种预定义的系统资源池
1:internal,内部资源池,只用于SQL数据库引擎,系统管理员不能改变和设置;
2:default,默认资源池,所有未分配资源池的的回话都使用默认资源池,默认资源池不能被修改和删除;
所有资源池的下限之和不得超过100%,因为系统会尽量满足资源池下限
资源池的上线可设置为下限到100%之间
--==========================================================
USE [master]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--创建资源池
CREATE RESOURCE POOL AppPool
WITH (
-- allocate at least % of the CPU bandwidth for admin queries
MIN_CPU_PERCENT = 0
-- do not let them exceed % either
, MAX_CPU_PERCENT = 70
-- admin queries should be small and we will allocate about %
-- of the server memory for them
, MIN_MEMORY_PERCENT = 0
, MAX_MEMORY_PERCENT = 80
)
GO
--创建负载组
CREATE WORKLOAD GROUP AppGroup
WITH (
-- use all defaults
IMPORTANCE = MEDIUM
, REQUEST_MAX_MEMORY_GRANT_PERCENT = 10
, REQUEST_MEMORY_GRANT_TIMEOUT_SEC = 100
, REQUEST_MAX_CPU_TIME_SEC = 10
, MAX_DOP = 0
, GROUP_MAX_REQUESTS = 0
)
USING AppPool
GO
--创建分类函数,将登陆用户TestUser的回话映射到负载组AppGroup
CREATE FUNCTION [dbo].[urgClassifier]()
RETURNS sysname
WITH SCHEMABINDING
AS
BEGIN
DECLARE @grp_name AS sysname;
SET @grp_name = ‘default‘;
IF (SUSER_SNAME()=‘TestUser‘)
BEGIN
SET @grp_name = ‘AppGroup‘;
END
RETURN @grp_name;
END
GO
--为资源调控器设置资源组
ALTER RESOURCE GOVERNOR
WITH (
CLASSIFIER_FUNCTION = [dbo].[urgClassifier]
)
GO
--更资源调控器设置
ALTER RESOURCE GOVERNOR RECONFIGURE
GO
--禁用资源调控器
ALTER Resource Governor DISABLE;