第七章——DMVs和DMFs(3)——用DMV和DMF监控TempDB

原文:第七章——DMVs和DMFs(3)——用DMV和DMF监控TempDB

前言:

我们都知道TempDB是SQLServer的系统数据库,且SQLServer的日常运作严重依赖这个库。因此,监控TempDB的性能问题尤为重要。在过去很长一段时间里面,很多人都忽略了TempDB的重要性并忽略了它的性能问题。这并不是一件好事,因为TempDB的性能会影响其他用户数据库的性能,所以需要时时刻刻注意TempDB的性能。

在一些查询的聚合、排序操作,游标操作和版本存储操作,联机索引创建,用户对象存储如临时表等,都将用到TempDB,作为DBA,需要经常监控TempDB,以便识别出资源消耗较大的操作。此时可以使用数据库相关的DMVs来完成。

在使用这些DMVs时,要清楚一些基础概念,SQLServer是如何组织数据的。所以先来了解页和区。

就像你所知道的,SQLServer主要通过两类文件来存储数据库。就是数据文件(mdf/ndf)和日志文件(ldf)。这里只讨论数据文件。因为页和区不适用于日志文件。

数据文件是SQLServer存储数据库的对象如表和索引的一种格式化文件。这些数据文件由更小的单元组成,这些单元叫做页。一个页存放8K的数据。

另外,区也有页来存放,一个区有8个顺序页组成。所以,一个区有64K,1MB有16个区。

包含数据的对象会分配到区中的页上。有两类的区——统一区和混合区,一个统一区被一个单独对象所独有,混合区可以存放能够放进8个页的8个不同对象。因为混合区可以共享整个区,所以也叫做共享区。当表很小时,会放入混合区,直到足够大占据一个区时,混合区就会整合成一个统一区。

本文将演示如何监控TempDB的性能。同时可以识别出引起TempDB空间增加的会话和任务。

准备工作:

本文将产生1000万数据,并存放到TempDB的局部临时表中。然后监控页分配和重新分配的情况。

步骤:

1、 
连到SQLServer

2、 
输入以下代码:

USE tempdb
GO
--检查表是否存在
IF OBJECT_ID(‘[dbo].[tbl_TempDBStats]‘) IS NOT NULL
    DROP TABLE [dbo].[tbl_TempDBStats]
--创建表用于存放页分配的明细
CREATE TABLE [dbo].[tbl_TempDBStats]
    (
      session_id SMALLINT ,
      database_id SMALLINT ,
      user_objects_alloc_page_count BIGINT ,
      user_objects_dealloc_page_count BIGINT ,
      internal_objects_alloc_page_count BIGINT ,
      internal_objects_dealloc_page_count BIGINT
    )
GO
--收集当前会话在执行查询之前的分配明细
INSERT  INTO [dbo].[tbl_TempDBStats]
        SELECT  session_id ,
                database_id ,
                user_objects_alloc_page_count ,
                user_objects_dealloc_page_count ,
                internal_objects_alloc_page_count ,
                internal_objects_dealloc_page_count
        FROM    sys.dm_db_session_space_usage
        WHERE   session_id = @@SPID
GO
--检查表是否存在
IF OBJECT_ID(‘TempDB.dbo.#tbl_SampleData‘) IS NOT NULL
    DROP TABLE TempDB.dbo.#tbl_SampleData
GO
--产生万数据并插入临时表
SELECT TOP 10000000
        SC1.object_id ,
        SC1.column_id ,
        SC1.name ,
        SC1.system_type_id
INTO    TempDB.dbo.#tbl_SampleData
FROM    sys.columns AS SC1
        CROSS JOIN sys.columns AS SC2
        CROSS JOIN sys.columns AS SC3
ORDER BY SC1.column_id
GO

--重新收集插入数据后的数据页分配情况
INSERT  INTO [dbo].[tbl_TempDBStats]
        SELECT  session_id ,
                database_id ,
                user_objects_alloc_page_count ,
                user_objects_dealloc_page_count ,
                internal_objects_alloc_page_count ,
                internal_objects_dealloc_page_count
        FROM    sys.dm_db_session_space_usage
        WHERE   session_id = @@SPID

3、 
然后输入以下代码,并注意执行前后的数据差异:

USE tempdb
GO
SELECT  *
FROM    [dbo].[tbl_TempDBStats]

4、 
结果如下:

5、 
运行以下查询查找TempDB空间分配情况:

SELECT  DB_NAME(FSU.database_id) AS DatabaseName ,
        MF.name AS LogicalFileName ,
        MF.physical_name AS PhysicalFilePath ,
        SUM(FSU.unallocated_extent_page_count) * 8.0 / 1024 AS Free_Space_In_MB ,
        SUM(FSU.version_store_reserved_page_count
            + FSU.user_object_reserved_page_count
            + FSU.internal_object_reserved_page_count
            + FSU.mixed_extent_page_count) * 8.0 / 1024 AS Used_Space_In_MB
FROM    sys.dm_db_file_space_usage AS FSU
        INNER JOIN sys.master_files AS MF ON FSU.database_id = MF.database_id
                                             AND FSU.file_id = MF.file_id
GROUP BY FSU.database_id ,
        FSU.file_id ,
        MF.name ,
        MF.physical_name

6、 
结果如下:

分析:

在本文的开片中,首先创建了一个表tbl_TempDBStats以便存放页分配和释放的统计数据。然后通过查询sys.dm_db_session_space_usage,获取分析信息。把所有用户定义对象和系统内置对象都插入表中。

下一个查询将产生1000万数据,并插入临时表#tbl_SampleData。使tempdb的分配情况发生改变。

插入数据以后,检查tbl_TempDBStats表,可以得出一些对比信息,最后通过一个DMV,sys.dm_db_file_space_usage。可以看出以MB为单位的分配情况。

注意:sys.dm_db_file_space_usage ,sys.dm_db_session_space_usage这两个DVM仅适用于tempdb。

时间: 2024-08-30 12:48:42

第七章——DMVs和DMFs(3)——用DMV和DMF监控TempDB的相关文章

第七章——DMVs和DMFs(1)

原文:第七章--DMVs和DMFs(1) 简介: 从SQLServer2005开始,微软引入了一个名叫DMO(动态管理对象)的新特性,DMO可以分为DMFs(Dynamic Manage Functions,动态管理函数)和DMVs(Dynamic Manage Views,动态管理视图)两部分.这些函数和视图用于查找SQLServer实例内部统计信息以供性能监控所用.它们提供实时的,关于SQLServer内部工作的,能用于性能分析和性能故障排除的各种统计信息. 所有的DMO都属于sys架构,并

第七章——DMVs和DMFs(4)——用DMV和DMF监控磁盘IO

原文:第七章--DMVs和DMFs(4)--用DMV和DMF监控磁盘IO 前言: 本文为本系列最后一篇,作为DBA,你必须经常关注磁盘的I/O问题,一旦出现问题,要尽快分析出是什么问题.SQLServer同样提供了一些列与I/O相关的DMO来做监控. 本文介绍如何使用DMO来监控I/O子系统的性能并找到I/O瓶颈.通过本文,可以区分不同数据库的I/O使用模式.一旦发现有数据库的I/O很高,可能需要考虑把数据库迁移到单独的磁盘,或者深入研究I/O产生的问题. 准备工作: 本文将演示如何监控数据库文

第七章

第七章 控制发光二极管. 尽管linux 驱动直接和硬件打交道,但并不是linux驱动直接向硬件中的内存写数据,而是与本机的i/o内存进行交互.所谓I/O内存是通过各种接口(PCI, USB.蓝牙以太网等)连接到主机的硬件在主机的内存映射.Linux内核提供了多个与I/O内存交互的函数.Linux内核的内存管理模块负责同步I/O内存与硬件的数据. 每一个连接Linux 的硬件在I/O内存中都会有映射首地址.在使用ioread 32.ioread32等函数读写I/O内存时需要指定这些首地址.Led

第七章:常用类

第七章:常用类 包装类 java中有8中基本类型,对应有八种包装类作用:包装类中封装了该类型常用的属性和方法,以方便操作.byte---->Byteshort--->Shortint--->Integerlong---->Longfloat---->Floatdouble---->Doublechar---->Characterboolean---->Boolean装箱:将基本数据类型转换成包装类,经常通过构造方法完成.Integer i = new Int

构建之法学习(第七章 MSF)

第七章 MSF MSF(Microsoft Solution Framework)微软解决方案框架: MSF是一套大型系统开发指南,是微软推荐的软件开发方法,它描述了如何用组队模型.过程模型和应用模型来开发Client/Server结构的应用程序,是在微软的工具和技术的基础上建立并开发分布式企业系统应用的参考. 一.MSF 9条基本原则 1.推动信息共享与沟通 --把所有信息都保留并公开,讨论要包括所有涉及的角色,决定要公开并告知所有人. 当然,对牵涉到技术机密.安全性等信息要采取必要的保护措施

Android开发艺术探索——第七章:Android动画深入分析

Android开发艺术探索--第七章:Android动画深入分析 Android的动画可以分成三种,view动画,帧动画,还有属性动画,其实帧动画也是属于view动画的一种,,只不过他和传统的平移之类的动画不太一样的是表现形式上有点不一样,view动画是通过对场景的不断图像交换而产生的动画效果,而帧动画就是播放一大段图片,很显然,图片多了会OOM,属性动画通过动态的改变对象的属性达到动画效果,也是api11的新特性,在低版本无法使用属性动画,但是我们依旧有一些兼容库,OK,我们还是继续来看下详细

第九章 前七章总结考试答案

前七章总结测验见附件内容

ROS机器人程序设计(原书第2版)补充资料 (柒) 第七章 3D建模与仿真 urdf Gazebo V-Rep Webots Morse

ROS机器人程序设计(原书第2版)补充资料 (柒) 第七章 3D建模与仿真 urdf Gazebo V-Rep Webots Morse 书中,大部分出现hydro的地方,直接替换为indigo或jade或kinetic,即可在对应版本中使用. 提供ROS接口的3D软件比较多,本章以最典型的Gazebo介绍为主,从Player/Stage/Gazebo发展而来,现在独立的机器人仿真开发环境,目前2016年最新版本Gazebo7.1配合ROS(kinetic)使用. 补充内容:http://blo

构建之法第六、七章读后感

第六章 Scrum 是一个用于开发和维持复杂产品的框架 ,是一个增量的.迭代的开发过程.Scrum包括了一系列实践和预定义角色的过程骨架.Scrum中的主要角色包括同项目经理类似的Scrum主管角色负责维护过程和任务,产品负责人代表利益所有者,开发团队包括了所有开发人员. 敏捷流程一共有4步: 第一步:弄懂需求与任务是相互依赖的关系 第二步:想要学会把一个任务从产品层级的描述逐步细化到技术实现层面,那么技术能力和交流能力尤为重要的,根据每个人的能力来分配任务以保证任务的高效完成. 第三步:个人要