SQLServer资源调控器--自由分配您的资源

SQLServer资源调控器--自由分配您的资源,第1张

概述SQLServer资源调控器--自由分配您的资源 http://www.cnblogs.com/fygh/archive/2012/05/07/2489190.html      很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么 解决方法,不过从SQLServer2008开始,这个需求就变 SQLServer资源调控器--自由分配您的资源

http://www.cnblogs.com/fygh/archive/2012/05/07/2489190.HTML 

    很早之前就有朋友问过我,能否按业务的优先等级分配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 100)Group NightlyMaintenanceTasks USING adminQuerIEs;Group Adhocadmin USING adminQuerIEs;Group SAPUsers 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 @valSAPUsers';          Return @val;        end              APP_name() like Microsoft sql Server Management Studio%Set Adhocadminend            IS_MEMBER(ReportUsers')1        DailyExecReportsIF CONNECTIONPROPERTY(net_transportShared memory' and NightlyadminNightlyMaintenanceTasks@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 @i int100000000; @s varchar(100),@count int; While @i>0 begin Select @s=@@VERSION; select @countCOUNT(0) from sys.sysobjects set -1;

 

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

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

@H_391_403@

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

100)

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

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

10)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_ID50 查看资源池情况 select * from sys.dm_resource_governor_resource_pools

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

总结

以上是内存溢出为你收集整理的SQLServer资源调控器--自由分配您的资源全部内容,希望文章能够帮你解决SQLServer资源调控器--自由分配您的资源所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1163800.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存