博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server Governor: The unknown hero
阅读量:6478 次
发布时间:2019-06-23

本文共 5522 字,大约阅读时间需要 18 分钟。

 

Table of contents

Introduction

SQL Server is a massive RDBMS software. Even after so many years of using it, I always find something new in it. I wonder how many hidden gems still exist unexplored inside this huge giant.

The sad part is some of those features are only known to Microsoft (naturally, they created it, so..) and are unknown to most developers.

Recently I came across a scenario where I needed a quick solution. I had some heavy running queries and I wanted to specify a limit on the amount of resources they consume. These queries where eating up all the memory allocated to the SQL Server process and affecting other queries.

I was one of those lucky people to get introduced to this lovely unsung and quiet hero: SQL Server governor, which helped me resolve my issues. 

The strange thing is, it existed from 2008 and I never knew about it. So via this article I want to make a small effort of introducing this feature so that it does not die silently due to less usage. We all know Microsoft is known for making features obsolete (even if they are useful) if it is not used by many people. 

You can also see check out my site where I have written a huge number of :

What is the use of SQL Server Governor?

SQL Server is a giant processing engine which processes various kinds of workloads like SQL queries, transactions, etc. In order to process these workloads, the appropriate CPU power and RAM memory needs to be allocated.

Now workloads are of different nature: some are light workloads while some are heavy. You would never like heavy SQL operations hijacking the complete CPU and memory resources thus affecting other operations.

One way to achieve this is by identifying these SQL queries and putting a restriction on the maximum CPU and memory resource for these queries. So for example, as shown in the below figure, if you have some heavy SQL which does reporting, you would like to allocate to it 80% of the CPU and memory resources. While for lightweight SQL, you would like to allocate only 20%.

This is achieved by using SQL Server Governor.

How do we configure SQL Server Governor?

Configuring SQL Server governor is a four step process:

Step 1: Create a pool and provide the CPU and memory limitation.

So to create a resource pool, browse to the management folder, right click on Resource Governor, and click on “New resource pool”.

You can then create a resource pool like the one we have created in the below figure: “OurPool”.

Step 2: Specify the workload.

The next step is to specify the workload for that resource pool. Workloads are partitions which divide the pool into logical pieces to run your query load. For instance let’s say in this pool “OurPool” if you want to run SQL Management Studio and Reporting Services. You can create two workload partitions: one for Management Studio and the other for Reporting Services, see the previous image. You can also see how we have allocated 25% of the memory for Reporting Services and 75% for Management Studio.

So now whenever Management Studio or Reporting Services applications run, they will be allocated resources from this pool with a resource constraint as specified in the above image.

Step 3: Create a user defined function.

So now that we have created pools and workloads, the final step is to map the incoming SQL request to the appropriate workload. This is done by using a user defined function which is termed as “classifier functions”.

So go to the master database and create a function as shown below. You can see how the user defined function checks for the app name and assigns it to the workload group.

USE [master]GOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGO create FUNCTION [dbo].[Class_funct]() RETURNS SYSNAME WITH SCHEMABINDINGASBEGIN  DECLARE @workload_group sysname;   IF (APP_NAME() LIKE '%MANAGEMENT STUDIO%')      SET @workload_group = 'Managementstudio';  IF (APP_NAME() LIKE '%REPORT%')      SET @workload_group = 'Reporting';       RETURN @workload_group;END;

Step 4: Assign the function to the pool.

The final step is to assign the user defined function to the pool. Edit the pool and select the function from the dropdown. Do not forget to enable the resource governor.

See it working

One you have done the configuring part, let's test if this really works. So let’s go and run Performance Monitor. Click on Start, run and type “perfmon”, and press Enter.

Go to the counters; in counters, go to SQL Server resource pool stats. Select all the pool instances and add used memory counters from it.

Now go and run your SQL Server Management Studio and see how the “custompool” memory increases.

Note: You can see that there are two extra pools: “default” and “internal”. The default pool is used for all SQL Server activities. The internal pool is used exclusively for internal requests which come from the SQL server itself.

Summarizing how the Governor works

  1. When a request comes to SQL Server, it first checks if this is an internal request or a normal end user request.
  2. If it’s an internal request, it goes straight to the internal pool for resource allocation.
  3. If it’s an external request, the classifier function comes into action and checks what kind of workload it is, and accordingly assigns it to the pool (see the user defined function shown in the previous section of this article). 

Also via this article I would like to share this nice SQL Server training video “How indexes improve select query performance”:

转载于:https://www.cnblogs.com/flysun0311/archive/2012/10/05/2712251.html

你可能感兴趣的文章
Vitamio中文API文档(4)—— VitamioInstaller
查看>>
yii框架常用url地址
查看>>
python3.4学习笔记(十六) windows下面安装easy_install和pip教程
查看>>
MyGUI 解析
查看>>
Linux中的ls命令详细使用
查看>>
graph-tool文档(一)- 快速开始使用Graph-tool - 2.属性映射、图的IO和Price网络
查看>>
easyui treegrid逐步加载
查看>>
GraphicsLab Project之辉光(Glare,Glow)效果 【转】
查看>>
<转>Python: __init__.py 用法
查看>>
Linux Curl命令
查看>>
046 SparlSQL中的函数
查看>>
-27979 LoadRunner 错误27979 找不到请求表单 Action.c(73): Error -27979: Requested form not found...
查看>>
[LeetCode] Minimum Depth of Binary Tree
查看>>
,net运行框架
查看>>
Java 中 Emoji 的正则表达式
查看>>
Mixin Network第一届开发者大赛作品介绍- dodice, diceos和Fox.one luckycoin
查看>>
安卓Glide(4.7.1)使用笔记 01 - 引入项目
查看>>
中金易云:为出版社找到下一本《解忧杂货店》
查看>>
Flex布局
查看>>
Material Design之 AppbarLayout 开发实践总结
查看>>