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

来源:未知 责任编辑:责任编辑 发表时间:2015-09-09 15:37 点击:

很早之前就有朋友问过我,能否按业务的优先等级分配SQLServer的资源,使得不同的应用能得到不同的响应,SQLServer2008之前对这个需求貌似没有什么
解决方法,不过从SQL Server2008开始,这个需求就变得很简单了,SQLServer直接就为我们提供了按用户的要求分配资源的能力,下面我们就来介绍这个功能。
 
    SQLServer资源调控器分成三个部分:资源池、负载组和分类器函数;资源池为我们提供了将资源(CPU、Memory等)划分到不同的载体中,负载组承载负载并将这些负载映射到资源池,分类器函数将不同的会话映射到不同的负载组中。  www.2cto.com  
 
资源池:
 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地址/应用程序名、用户名等)分别分配组。
按以下条件分配组:  www.2cto.com  
  一个用户接入并使用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
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • sql常见面试题
  • SQL SERVER 2005性能之跟踪
  • LINUX上RMAN自动备份脚本
  • sql server 列转行
  • SQL SERVER2008日常自动化备份
  • SQL Server 2005 镜像构建手册
  • SQL编程(一)
  • 如何将多个SQL查询统计结果一次显示出来
  • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1