SQLServer资源调控器--自由分配您的资源
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 WorkLoad Group DailyExecReports USING UserQueries; 删除负载组 drop WorkLoad Group DailyExecReports? 分类器函数: ? ? ?分类器函数将接入的会话分类,并为会话的请求和查询分配一个负载组。你可以根据连接串中的任意属性(IP地址/应用程序名、用户名等)分别分配组。 按以下条件分配组:
创建资源池 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;
?我们先将资源池按一比一的比例分配: 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对应到了不同的资源池中。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |