1. 跟踪标记 (Trace Flag) 1117, 1118 文件增长及空间分配方式
跟踪标记:1117
功能:
- 默认,同一个文件组下的多个文件,如果某个文件没有可用空间,且设置了自动增长,则该文件自动增长,其他文件大小保持不变;
- 开启后,同一文件组下的多个文件,如果某个文件没有可用空间,且设置了自动增长,文件组下所有文件同时增长,每个文件涨幅取决于自身filegrowth设置;
用途:
主要用于tempdb性能的优化,解释如下:
- 通常tempdb被配置为primary文件组下包含多个等大的数据文件,以最大化使用CPU,并且能有效减少对于PFS, SGAM, GAM的竞争(latch contention);
- 同一个文件组下的多个文件是等比例填充数据的(proportional fill),也就是说所有的文件最终几乎同时被填满,这时需要文件自动增长空间;
- 然后就会发现每个文件是逐个根据自身的filegrowth各自增长,这样多次文件增长反而带来不必要的开销,尤其是当filegrowth设置的不够大时;
- 开启跟踪标记1117后,文件组下所有文件同时增长,当然如果将tempdb的多个数据文件初始化为一个较大的大小,也可以不考虑这个选项,因为文件不需要增长;
备注:
在SQL Server 2016里,跟踪标记1117已经不再生效,功能被如下SQL语句所代替
ALTER DATABASE [Database_Name]
MODIFY FILEGROUP [FileGroup_Name] AUTOGROW_ALL_FILES;
--自定义文件组,默认为AUTOGROW_SINGLE_FILE
跟踪标记:1118
功能:
- 默认,对于新建的表或索引,会先在混合区(mixed extent)分配空间,等到表或索引占用空间超过8个页后,才会在统一区(uniform extent)分配空间;
- 开启后,对于新建的表或索引,直接使用统一区(uniform extent)分配空间;
用途:
主要用于tempdb性能的优化,解释如下:
- 表或索引被创建时,首先必须得使用PFS和SGAM页在混合区分配空间;
- 在大量使用临时表的场景,对于PFS和SGAM页的竞争(latch contention)会更加明显;
- 开启跟踪标记1118后,避开对SGAM页的使用,在统一区分配新建对象的空间,也许有人会担心全部使用统一区后GAM页的竞争,GAM页管理的是区(extent),而SGAM虽然管理的也是区(extent),但是一个区可以被多个对象使用,所以相比之下GAM页的压力要小很多;
备注:
在SQL Server 2016里,跟踪标记1118已经不再生效,功能被如下SQL语句所代替
ALTER DATABASE [Database_Name]
SET MIXED_PAGE_ALLOCATION OFF
--自定义数据库,默认即为OFF,不使用混合区
小结:
对于tempdb的优化,通常会配置多个数据文件,以及开启1118跟踪标记,而1117更像是在文件增长方式上,对这两者的补充。
从SQL Server 2016开始:
(1) 对于1117,1118这两个跟踪标记不再生效,但有了文件组/数据库选项,粒度更小,而不用像之前那样,开启全局的跟踪标记(对所有数据库生效),更为方便控制;
(2) 对于tempdb,文件增长:默认为文件组内全部增长;空间分配:默认为不使用混合区;
use tempdb
select * from sys.filegroups
--is_autogrow_all_files
-- select * from sys.databases where name = 'tempdb'
--is_mixed_page_allocation_on
--
(3) 对于用户新建的数据库,文件增长:默认为文件组内单个文件增长,和以前一样;空间分配:默认为不使用混合区;
use DBA
select * from sys.filegroups
--is_autogrow_all_files
-- select * from sys.databases where name = 'DBA'
--is_mixed_page_allocation_on
--
(4) 另外在安装SQL Server 2016时,还根据CPU核数动态设置了tempdb的文件数,所以到了SQL Server 2016,tempdb的优化选项几乎全部采用默认即可。
参考:
SQL Server 2016 – Trace Flag 1117 Changes
http://www.sqlservergeeks.com/sql-server-2016-trace-flag-1117-changes/
Working with tempdb in SQL Server 2005
https://technet.microsoft.com/en-us/library/cc966545.aspx
kb/328551
https://support.microsoft.com/en-us/kb/328551
kb/2154845
https://support.microsoft.com/en-us/kb/2154845
Trace Flags (Transact-SQL)
https://msdn.microsoft.com/en-us/library/ms188396.aspx
Trace Flags 1117, 1118, and Tempdb Configuration
https://www.brentozar.com/archive/2014/06/trace-flags-1117-1118-tempdb-configuration/
《Fast Track Data Warehouse 2.0 Architecture.docx》
1. 跟踪标记 (Trace Flag) 1117, 1118 文件增长及空间分配方式的更多相关文章
- 0. 跟踪标记 (Trace Flag) 简介
一. 什么是跟踪标记 SQL Server 跟踪标记(Trace Flag),像是一个开关,可用来自定义SQL Server的某种行为或特性,在性能诊断,系统调试等方面较为常用.比如:开启1204或1 ...
- 4. 跟踪标记 (Trace Flag) 610 对索引组织表(IOT)最小化日志
跟踪标记:610 功能: 用批量导入操作(Bulk Import Operations)加载数据时,对于索引组织表(即有聚集索引的表) 最小化日志: 上图为simple/bulk-logged恢复模式 ...
- 5. 跟踪标记 (Trace Flag) 834, 845 对内存页行为的影响
跟踪标记:834 功能: 在64位的windows环境下,为SQL Server开启这个跟踪标记,那么SQL Server 会使用大页(Large pages)为内存缓冲区(buffer pool)分 ...
- 3. 跟踪标记 (Trace Flag) 1204, 1222 抓取死锁信息
跟踪标记:1204/1222 功能及用途: 捕获SQL Server死锁信息,并自动存放到错误日志(ERRORLOG)中. 举例: USE tempdb GO CREATE TABLE t1(id i ...
- 2. 跟踪标记 (Trace Flag) 3604, 3605 输出DBCC命令结果
跟踪标记:3604 功能: 输出DBCC命令返回结果到查询窗口(通常是SSMS窗口),类似print命令的显示效果: 用途: 常用于获取DBCC IND, DBCC PAGE命令的输出结果,因为这2个 ...
- (5.2.2)配置服务器参数——dbcc跟踪标记(trace)
关键字:跟踪标记,跟踪 [1]常规dbcc命令 dbcc help('?') --查看dbcc 所有命令,常规下只有32个常用的dbcc TRACEON(2588) --指定了2588标记的话,你就可 ...
- DBA应该知道的一些SQL Server跟踪标记
跟踪标记是什么? 对于DBA来说,掌握Trace Flag是一个成为SQL Server高手的必要条件之一,在大多数情况下,Trace Flag只是一个剑走偏锋的奇招,不必要,但在很多情况下,会使用这 ...
- DBCC--常用跟踪标记
使用DBCC TRACEON 和DBCC TRACEOFF来打开和关闭跟踪标记 使用DBCC TRACESTATUS来查看所有打开的跟踪标记 --260:打印关于扩展存储过程动态链接库的版本信息 -- ...
- SQL Server中关于跟踪(Trace)那点事
前言 一提到跟踪俩字,很多人想到警匪片中的场景,同样在我们的SQL Server数据库中“跟踪”也是无处不在的,如果我们利用好了跟踪技巧,就可以针对某些特定的场景做定向分析,找出充足的证据来破案. 简 ...
随机推荐
- centos7防暴力破解五种方法
什么是暴力破解,简单来说就是对一个服务器进行无数次尝试登陆,并用不同的密码进行登陆直到可以登陆成功.暴力破解的基本步骤可以分为以下几步: 1. 找到对应的linux服务器 Ip地址 2.扫描端口 ...
- 2013年8月12日Python的5个最有价值问题
问:Python怎么在字典里删除值但保留相应的键 答: 假设3都在值里,而非键>>> for v in D1.values():... if 3 in v:... ...
- if 和case
select case 'O' when 'O' then (1*5-6) when 'C' then (1*5-6) when 'EC' then (1*5-6) --else null --end ...
- C#中const 和 readonly 修饰符的用法详解
1.const是不变常量,在编译的时候就需要有确定的值,只能用于数值和字符串,或者引用类型只能为null.(这里为什么要把字符串单独拿出来?是因为字符串string是引用类型,但是使用的时候却感觉是值 ...
- secureCRT的文件上传技巧
现在我们经常会习惯性的使用windows系统,但现在开发项目和维护中经常都在使用linux服务器,以为它的性能更强.更精简. 学习大数据的同志们和维护后端的同志们,推荐一下secureCRT软件,用起 ...
- fuz 2159 WuYou
Problem 2159 WuYou Accept: 16 Submit: 64Time Limit: 1000 mSec Memory Limit : 32768 KB Problem ...
- Hibernate中查询优化策略
Hibernate查询优化策略 ² 使用延迟加载等方式避免加载多余数据 ² 通过使用连接查询,配置二级缓存.查询缓存等方式减少select语句数目 ² 结合缓存机制,使用iterate()方法减少查询 ...
- 推荐 VSCode 上特别好用的 Vue 插件 - vetur
作者 @octref 此前 V2EX 发过帖子,最近新增代码补全功能,综合比较应该是目前 VSCode 上面最好用的 Vue 插件. 能够实现在 .vue 文件中: 语法错误检查,包括 CSS/SCS ...
- Git 学习之Git 基础(二)
Git 基础 读完本章你就能上手使用 Git 了.本章将介绍几个最基本的,也是最常用的 Git 命令,以后绝大多数时间里用到的也就是这几个命令.读完本章,你就能初始化一个新的代码仓库,做一些适当配置: ...
- linq中如何实现多个条件的联合查询
目前接触处理数据这一块比较多,在处理内存中的数据源的时候我一般使用的是linq,linq使用起来像sql语句一样,用法简单,功能强大. 最近需要实现一个从两个不同的文件读取不同的数据,然后根据这两个数 ...