SQL Server 中关于系统库Tempdb总结
Tempdb系统数据库是一个全局资源,可供连接到SQL Server实例的所有用户使用。
存储的内容项:
1、用户对象
用户对象由用户显示创建。这些对象可以位于用户会话的作用域中,也可以位于创建对象所用例程的作用域中。例程可以是存储过程、触发器或用户自定义函数。用户对象可以是一下项内容之一:
- 用户定义的表和索引
- 系统表和索引
- 全局临时表和索引
- table变量
- 表值函数中返回的表
2、内部对象
内部对象是根据需要由SQL Server数据库引擎创建的,用户处理SQL Server语句。内部对象可以在语句的作用域中创建和删除。内部对象可以是下列项之一:
- 用于游标或假脱机操作以及临时大型对象(LOB)存储的工作表
- 用于哈希连接或哈希聚合操作的工作文件
- 用于创建或重新生成索引等操作(如果指定了SORT_IN_TEMPDB)的中间排序结果,或者某些GROUP BY、ORDER BY或UNION查询的中间排序结果。
- 每个对象至少使用9页:一个IAM页,一个8页的区。
3、版本存储区
版本存储区是数据页的集合,它包含支持使用行版本控制的功能所需的数据行。主要用来支持快照(Snaphot)事务隔离级别,以及SQL Server2005推出的一些其它提高并法度的新功能。在SQL Server2005中,有两个版本存储区:公用版本存储区和索引生产版本区。包含以下内容:
- 由使用快照隔离界别或已提交读隔离界别(基于行版本控制)的数据库中的数据修改事务生成的行版本
- 由数据修改事务为实现联机索引操作、多个活动的结果集(MARS)以及AFTER触发器等功能而生成行版本
在SQL Server2005以后,tempdb需要的磁盘空间会多于早期版本。因此当升级到SQL Server2005或SQL Server2008后,管理员提供的tempdb磁盘空间可能得比以前要大一些,用以容纳当前生产工作负荷并满足使用tempdb的SQL Server功能的额外空间要求。
Tempdb空间使用跟踪
tempdb空间使用的一大特点,是只有一部分对象,比如:临时表、table 变量等,可以用sys.allcoation_units和sys.partitions这样的管理视图来管理。所以用sp_spaceused的结果和真实情况会有很大差异。
提示:tempdb的空间使用是不能用sp_spaceused来跟踪的。
DBCC SHOWFILESTATS还是可以反映数据库文件使用的整体情况的。
在2005版本以后引入了一个新的视图:sys.dm_db_file_space_usage;这张视图能反映出tempdb在如下几个大类的空间里使用分布:
select * from sys.dm_db_file_space_usage

其中:
database_id:数据库ID
file_id:文件ID,file_id映射到sys.dm_io_virtual_file_stats中的file_id,并且映射到sys.sysfile中的fileid
unallocated_extent_page_count:文件未分配区中的总页数,不包含已分配区中的未使用页
version_store_reserved_page_count:为版本存储分配的统一区中的总页数
user_object_reserved_page_count:为从统一区为数据库中的用户对象分配的总页数。计数中包括已分配区中未使用的页。可以使用sys.allocation_units目录视图中的total_pages列来返回用户对象每个分配单元保留的页计数
internale_object_reserved_page_count:从统一区为文件中的内部对象分配的总页数。计数包括已分配区中未使用的页
mixed_extent_page_count:文件的已分配混合区中的已分配和未分配总页数。混合区包含分配给不同对象的页。此计数器包含文件中的所有的IAM页
通过这个表的监视,就能知道temdb的空间被那个一块对象使用掉了,是用户对象(user_object_reserved_page_count),还是系统对象(internal_object_reserved_page_count),还是版本存储区对象(version_store_reserved_page_count)。
tempdb在生产环境中的设置的初始大小其实是一个经验值,也就是说没有一个好的固定值,但是我们可以根据工作负荷来确定该值的大小值:
1、设置tempdb的自动增长
2、模拟各个单独的查询或工作任务,同时监视tempdb空间使用
3、模拟执行一些系统维护操作,例如,重新生成索引,同时监视tempdb空间
4、使用前面2和3步中tempdb空间使用值来预测总的工作负荷下,会使用多少空间;并针对计划的并发度调整此值。例如,如果一个任务会使用10GB的tempdba空间,而在生产环境里,最多可能会有4个这样的任务同时运行,那就要至少预留40GB的空间。
5、设置tempdb在生产环境下的初始大小。同时也开始自动增长。
Temp文件个数以及大小设置,不但满足用户任务的需求,还要考虑到性能优化。
我们利用脚本来跟踪一下,看看是什么样的操作导致了SQL Server要这样大规模的使用tempdb,然后分析一下是正常行为还是异常行为,监视SQL Server的行为当然可以利用SQL Trace来完成。可是管理员并不能预期造成大量使用tempdb的语句会在什么时刻运行。这些语句可能一周只做一次。而且开跟踪毕竟对SQL Server来讲是一个比较昂贵的事情,就算没有性能副作用,如果一直开着SQL Trace,也会产生大量的跟踪文件,对硬盘是个比较重的负担。
推荐的“轻量级”的操作是以一定的时间间隔运行能够监视系统运行状况的DBCC命令、查询管理视图(DMV)以及管理函数(DMF)等,把这个结果输出到一个文件里。
新开一个连接,我们输入以下常规脚本:

select @@SPID
go
use AdventureWorks
go
select GETDATE()
go
select * into #MyOrdersDetail
from Sales.SalesOrderDetail
--创建一个临时表
--这个操作应该会申请用户对象页面
go
waitfor delay '0:0:2'
select GETDATE()
go
drop table #MyOrdersDetail
--删除一个临时表
--这个操作用户对象页面数量应该会下降
go
waitfor delay '0:0:2'
select GETDATE()
go
select top 100000 * from
[Sales].[SalesOrderDetail]
inner join [Sales].[SalesOrderHeader]
on [Sales].[SalesOrderHeader].[SalesOrderID] =
[Sales] .[SalesOrderHeader].SalesOrderID;
--这里做了一个比较大的连接,应该会有系统对象申请
go
select GETDATE()
--join 语句做完以后系统对象页面数目应该会下降
go

然后另开一个窗口,我们输入监控脚本,输出结果以文本方式存储

use tempdb
--每隔1s运行一次,直到用户手工终止脚本运行
while 1=1
begin
select GETDATE()
--从文件级看temp使用情况
dbcc showfilestats
--第一个会话
--返回所有做过空间申请的会话信息
select 'Tempdb' as DB,GETDATE() as Time,
sum(user_object_reserved_page_count)*8 as user_obectskb,
SUM(internal_object_reserved_page_count)*8 as internal_objects_kb,
SUM(version_store_reserved_page_count)*8 as version_store_kb,
SUM(unallocated_extent_page_count)*8 as freespace_kb
from sys.dm_db_file_space_usage
where database_id=2 --第二个会话
--这个管理视图能够反映当时tempdb空间的总体分配
select t1.session_id,
t1.internal_objects_alloc_page_count,
t1.user_objects_alloc_page_count,
t1.internal_objects_dealloc_page_count,
t1.user_objects_dealloc_page_count,
t3.*
from sys.dm_db_session_space_usage t1,
--反映每个会话累计空间申请
sys.dm_exec_sessions as t3
--每个会话信息
where
t1.session_id=t3.session_id
and (t1.internal_objects_alloc_page_count+t1.internal_objects_dealloc_page_count+t1.user_objects_alloc_page_count+t1.user_objects_dealloc_page_count)>0 --第三会话
--返回正在运行并且做过空间申请的会话正在运行的语句
select t1.session_id,
st.text
from sys.dm_db_session_space_usage as t1,
sys.dm_exec_requests as t4
cross apply sys.dm_exec_sql_text(t4.sql_handle) as st
where t1.session_id=t4.session_id
and t1.session_id>50
and (t1.internal_objects_alloc_page_count+t1.internal_objects_dealloc_page_count+t1.user_objects_alloc_page_count+t1.user_objects_dealloc_page_count)>0 waitfor delay '0:0:1'
end

我们先运行监控,然后再运行一般脚本,可以分析一下跟踪结果。
可以看到在新建临时表的时候,对于Tempdb的申请空间有所增加。
SQL Server 中关于系统库Tempdb总结的更多相关文章
- 《SQL Server企业级平台管理实践》读书笔记——SQL Server中关于系统库Tempdb总结
Tempdb系统数据库是一个全局资源,可供连接到SQL Server实例的所有用户使用. 存储的内容项: 1.用户对象 用户对象由用户显示创建.这些对象可以位于用户会话的作用域中,也可以位于创建对象所 ...
- SQL Server 中如何移动tempdb到新的位置
操作步骤:1.检查tempdb的逻辑名字和它的存在位置.可以使用下面语句: SELECT name, physical_name FROM sys.master_files WHERE databas ...
- SQL Server中tempdb的管理
原文:SQL Server中tempdb的管理 资料来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive/tags/tempdb/ ht ...
- SQL Server中的TempDB管理——TempDB基本知识(为什么需要版本存储区)
原文:SQL Server中的TempDB管理--TempDB基本知识(为什么需要版本存储区) 参考资料来自: http://blogs.msdn.com/b/sqlserverstorageengi ...
- SQL Server中TempDB管理(version store的逻辑结构)
原文:SQL Server中TempDB管理(version store的逻辑结构) 原文来自: http://blogs.msdn.com/b/sqlserverstorageengine/arch ...
- SQL Server中TempDB管理(版本存储区的一个example)
原文:SQL Server中TempDB管理(版本存储区的一个example) 原文来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive ...
- SQL Server中tempdb的management
对<SQL Server中tempdb的management>的一些更正和补充 对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这 ...
- 对《SQL Server中tempdb的management》的一些更正和补充
对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这篇文章:SQL Server中tempdb的management 发现里面有些内容不是很准确 文 ...
- SQL Server 中4个系统数据库,Master、Model、Msdb、Tempdb。
(1)Master数据库是SQL Server系统最重要的数据库,它记录了SQL Server系统的所有系统信息.这些系统信息包括所有的登录信息.系统设置信息.SQL Server的初始化信息和其他系 ...
随机推荐
- [Algorithm] 206. Reverse Linked List
Reverse a singly linked list. Example: Input: 1->2->3->4->5->NULL Output: 5->4-> ...
- apache pinot-docker-compose 运行试用
apache pinot 是一个实时的OLAP 数据存储,同时包含了自己的查询语言,因为maven 构建花费时间较大 所以使用docker-compose 运行 docker-compose 文件 ...
- Git常用命令及配置
Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件. Git ...
- [golang][gui]Hands On GUI Application Development in Go【在Go中动手进行GUI应用程序开发】读书笔记03-拒交“智商税”,解密“GUI”运行之道
和老外的原文好像没多大联系了,哈哈哈,反正是读书笔记,下面的内容也是我读此书中的历程,也写进来吧.不过说实话,这框架的作者还挺对我脾气的,哈哈哈. 拒交“智商税”,解密“GUI”运行之道 我很忙 项目 ...
- java 中类初始化,构造方法,静态成员变量,静态块的加载顺序
1.编译和运行概念要搞清:编译即javac的过程,负责将.java文件compile成.class文件,主要是类型.格式检查与编译成字节码文件,而加载是指java *的过程,将.class文件加载到内 ...
- fiddler自动生成jmeter测试脚本
概述 昨天我们在课堂上讲了如何通过fiddler抓包,单一接口可以复制到jmeter中进行接口测试,那么如果抓包获取了大量的接口,我们如何快速实现接口转换成jmx文件呢? 今天给大家介绍fiddler ...
- 一周 GitHub 开源项目推荐:阿里、腾讯、陌陌、bilibili……
阅读本文大概需要 2.8 分钟. 陌陌风控系统正式开源 陌陌风控系统静态规则引擎,零基础简易便捷的配置多种复杂规则,实时高效管控用户异常行为. GitHub 地址 https://github.com ...
- docker时区问题
解决: dockerfile: RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime#update application timezoneR ...
- MyBatis传入参数为list、数组、map写法
1.foreach简单介绍: foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有item,index,collection,open,sep ...
- 20175211 《实验三 敏捷开发与XP实践》实验报告
目录 一.实验内容 二.实验步骤 四.实验过程中遇到的问题及其解决方法 五.心得体会 六.码云链接 七.结对成员链接 八.参考资料 一.实验内容 (1)编码标准 (2)Git的使用 (3)重构 (4) ...