最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

SQLServer资源调控器

来源:动视网 责编:小采 时间:2020-11-09 07:37:50
文档

SQLServer资源调控器

SQLServer资源调控器:很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么 解决方法,不过从SQLServer2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求
推荐度:
导读SQLServer资源调控器:很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么 解决方法,不过从SQLServer2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求


很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么 解决方法,不过从SQLServer2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求分配

很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么

解决方法,不过从SQLServer2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求分配资源的能力,下面我们就来介绍这个功能。

SQLServer资源调控器分成三个部分:资源池、负载组和分类器函数;资源池为我们提供了将资源(CPU、Memory等)划分到不同的载体中,负载组承载负载并

将这些负载映射到资源池,分类器函数将不同的会话映射到不同的负载组中。

资源池:

08提供了两种预先定义好的资源池

内部池:内部池只用于SQLServer数据库引擎,系统管理员不能改变和设置;

默认池:默认池用于没有分配资源池的各种负载,因此,如果你不指定资源调控器,全部负载将使用默认池。默认池也不能改变或删除,但是可以修改它的资源上

下限。

资源池上下限要求:

各个资源池的下限之和不能超过100%,因为SQLServer会尽力满足每个下限;

上限可以设置为下限和100%之间的任意值。


以下是关于资源池的基本操作:

--创建资源池
Create Resource Pool UserQueries with(max_cpu_percent=100) --删除资源池
drop Resource Pool UserQueries

负载组:

负载组可以让管理员轻松地监控资源使用情况,在不同的资源池之间移动某类负载。

负载组被映射到资源池上,一个资源池可以有零个或更多负载组,一个负载组为一组用户会话提供一个桶。

--创建负载组
Create WorkLoad Group DailyExecReports USING UserQueries;

--删除负载组
drop WorkLoad Group DailyExecReports

分类器函数:

分类器函数将接入的会话分类,并为会话的请求和查询分配一个负载组。你可以根据连接串中的任意属性(IP地址/应用程序名、用户名等)分别分配组。

按以下条件分配组:

  • 一个用户接入并使用SAP_Login登录名,则为他分配SAPUsers负载组;
  • 一个用户接入程序名是SSMS,则让它成为AdhocAdmin负载组的一员;
  • 一个用户是ReportUsers组一员,则让它成为DaliyExecReports负载组一员;
  • 一个用户以共享内存连接,并在NightlyAdmin用户组中,则分配NightlyMaintanceTask组。
  • --创建资源池
    Create Resource Pool AdminQueries with(max_cpu_percent=100)
    Create Resource Pool UserQueries with(max_cpu_percent=100)
    
    --创建负载组
    Create WorkLoad Group NightlyMaintenanceTasks USING AdminQueries;
    Create WorkLoad Group AdhocAdmin USING AdminQueries;
    Create WorkLoad Group SAPUsers USING UserQueries;
    Create WorkLoad Group DailyExecReports USING UserQueries;
    
    --创建分类器函数
     USE master
     GO
     create FUNCTION class_func_1()
     Returns sysname with schemabinding
     begin
     Declare @val sysname
     --Handle workload groups defined by login names
     IF SUSER_SNAME()='SAP_Login'
     begin
     SET @val='SAPUsers';
     Return @val;
     end
     
     IF APP_NAME() like 'Microsoft SQL Server Management Studio%'
     begin
     Set @val='AdhocAdmin';
     Return @val;
     end
     
     IF IS_MEMBER('ReportUsers')=1
     begin
     Set @val='DailyExecReports';
     Return @val;
     end
     
     IF CONNECTIONPROPERTY('net_transport')='Shared memory' and IS_MEMBER('NightlyAdmin')=1
     begin
     Set @val='NightlyMaintenanceTasks';
     Return @val;
     end
     
     Return @val;
     end

    绑定分类器函数:

    --将分类器函数绑定到资源调控器上
     Alter Resource Governor With(Classifier_Function=dbo.class_func_1);

    启用和禁用分类器函数:

    --启用
     ALter Resource Governor Reconfigure;
    --禁用
     ALTER RESOURCE GOVERNOR DISABLE;

    测试:

    现在我们分别使用SAP_Login和sysadmin用户调用此脚本

    --测试脚本(分别使用SAP_Login和sysadmin用户调用此脚本)
     set nocount on 
     Declare @i int=100000000;
     Declare @s varchar(100),@count int;
     While @i>0
     begin
     Select @s=@@VERSION;
     select @count=COUNT(0) from sys.sysobjects 
     set @i=@i-1;
     end

    通过性能计数器查看资源分配:

    我们可以选择性能计数器的资源统计:SQL Server:Resource Pools Stats;

    我们先将资源池按一比一的比例分配:

    Create Resource Pool AdminQueries with(max_cpu_percent=100)
    Create Resource Pool UserQueries with(max_cpu_percent=100)

    运行测试脚本,显示的CPU利用率图如下

    现在将资源分配做如下调整:

    Create Resource Pool AdminQueries with(max_cpu_percent=10)
    Create Resource Pool UserQueries with(max_cpu_percent=90)

    再次运行测试脚本,显示的CPU利用率图如下

    可以看到,当我们调整资源后,两个Session中运行同样的脚本,它们所使用的资源差别很大,这样就达到了根据不同的应用分配不同的资源的目的。

    DMV查看资源池:

    --查看Session所在的资源池
     select s.session_id,s.login_name ,s.program_name,s.group_id,g.name 
     from 
     sys.dm_exec_sessions s join sys.dm_resource_governor_workload_groups g
     on s.group_id=g.group_id
     where session_id>50

    --查看资源池情况
     select * from sys.dm_resource_governor_resource_pools

    可以看到,我们创建的两个资源池(还有两个是系统资源池和默认资源池),而且不同的Session对应到了不同的资源池中。

    文档

    SQLServer资源调控器

    SQLServer资源调控器:很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么 解决方法,不过从SQLServer2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求
    推荐度:
    标签: 资源 朋友 就有
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top