很早之前就有朋友问过我,能否按业务的优先等级分配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对应到了不同的资源池中。
