您好,欢迎访问一九零五行业门户网

第十九章使用资源调控器管理资源(1)使用SQLServer Man

本系列包含: 1、使用sqlserver management studio 配置资源调控器 2、使用t-sql配置资源调控器 3、监控资源调控器 前言: 在前面的章节,提到过可以通过多种配置数据库服务器的方式来提高性能。如索引、统计信息、hints、物理设计和服务器配置等。 当你完成
本系列包含:
1、 使用sqlserver management studio 配置资源调控器
2、 使用t-sql配置资源调控器
3、 监控资源调控器
前言:      在前面的章节,提到过可以通过多种配置数据库服务器的方式来提高性能。如索引、统计信息、hints、物理设计和服务器配置等。
      当你完成上面那些配置后,还依旧有少量存储过程、查询运行得很慢时,由于硬件资源限制,可能已经没什么好调整。如一个数据库服务器支撑着多个应用系统,其中一个是报表系统,而报表系统往往都是非常耗资源的。
      在2008之前,对于这种问题,很难作出有效的解决方法。从2008开始,引入了一个资源调控器(resourcegovernor)来协助解决这类问题。资源调控器(下面简称rg),可以管理服务器上cpu和内存资源。不同类型的请求可以被分配到不同的资源。
rg的功能可以分为3个组件:
1、 分类(classification)
2、 资源池(resource pool)
3、 工作负荷组(workload group)
rg的基本功能/体系
分类(classification):定义一个用户自定义标量函数作为rg的分类函数,每当请求到达时,分类函数就会执行,区分请求的类型,然后放到特定的工作负荷组(workload group)中。
工作负载组(workloadgroup):一个逻辑单元,包含了一组资源。属于特定的资源池(resource pool)sqlserver创建了两个默认的工作负载组,internal和default。
资源池(resourcepool):包含对请求分配特定工作负载组的资源规则定义,sqlserver同样创建了两个资源池internal和default。
通过sqlservermanagement studio 配置资源调控器:      在开始之前,先来创建一个现实环境,假设adventureworks数据库是生产数据库,且有数十亿的数据。这个库提供多个应用程序使用。一个应用程序是用于web程序,一个是oltp。另外一个应用程序是报表系统。当查询报表的时候,会影响到web程序,为了解决这个问题,可以借助rg来保存web程序的cpu和内存资源。这里保留web程序获得最少50%的cpu和内存,报表使用25%。
本文将演示使用sqlserver management studio(下称ssms)来实现。
准备工作:本文将创建两个资源池和工作负载组。用于给web和报表程序之用。独立的用户名分类函数区分请求很有帮助,基于用户名,分类函数将发送请求到特定的工作负载组。
步骤:1、 打开ssms,确保这个登录有管理员权限,如果不能,那需要有alter login和control server的权限。
2、 在新建窗口输入,注意本文使用adventureworks2012数据库:
use mastergo create login [aw_webappuser] with password=n'aw_webappuser123' ,default_database=adventureworks2012go use adventureworks2012go create user [aw_webappuser] for login [aw_webappuser]goalter role [db_owner] add member [aw_webappuser]go create login [aw_reportappuser] with password=n'aw_reportappuser123',default_database=adventureworks2012go use adventureworks2012gocreate user [aw_reportappuser] for login [aw_reportappuser]goalter role [db_owner] add member [aw_reportappuser]go
3、 创建分类函数: 
use mastergo create function dbo.rgclassifier( )returns sysname with schemabindingas begin declare @workload_groupname sysname if suser_name() = 'aw_webappuser' set @workload_groupname = 'rg_webapp' else if suser_name() = 'aw_reportappuser' set @workload_groupname = 'rg_reportapp' else set @workload_groupname = 'default' return @workload_groupname end
4、 打开ssms,右键资源调控器节点,选择【属性】,就见到如下:
5、 点击启用【启用资源调控器】:
6、 在分类函数名下拉框中,选择dbo.rgclassifier():
7、 在资源池网格中,可以找到两个默认资源池defalut和internal,现在添加一个新的资源池叫做rp_webapp,并配置为如图,记住总和不能超过100:
8、 在资源池的工作负荷组:rp_webapp中,创建一个新的工作负荷组rg_webapp,并配置cpu时间为300:
9、 在资源池网格中,按上述步骤添加rp_reportapp,并把最小cpu和内存设为25,cpu时间为300:
10、点击确定后,打开资源调控器节点:
分析:      在连接了sqlserver之后,先执行脚本创建用户,用于标识不同应用程序访问数据库。通过账号,分类函数会把登录名的请求发送到对应的资源池和工作负荷组。
      在创建类分区函数dbo.rgclassifier(),并在图形界面中调用这个函数。默认情况下资源调控器是禁用的,为了使其工作,需要手动启用。除了图形界面,也可以使用t-sql语句:alter resourcegovernor reconfigure命令来启动。
      如果请求不属于新建的两个资源池,会分配到default工作负荷组和default资源池。internal工作负荷组是sqlserver内部使用的,并且dac(专用管理员连接)是不受rg分类影响。
最后通过图形界面查看是否建立成功。
扩充信息:       在现实世界中,在实施资源调控器之前,需要对各个应用程序的资源请求做一个趋势分析,可以帮助你更好地分配资源。
       在资源池中定义的min参数是不共享的,也就是别的请求不能占用这部分,是专用的资源。资源调控器可以有多个资源池。这就是为什么min中的百分比总和不能超过100.
        另一方面,max参数的值是共享的,实际的max值会根据min的值来调整。
其它类似信息

推荐信息