tempdb 日志文件增长的问题
前两天在一个客户那里发现tempdb log 文件增长很大,已经使用40GB了,而tempdb log 文件总的分配空间是70GB,并且日志空间貌似不能重用,他们使用sql 2012 打的sp4补丁,远程分析问题,没有发现长时间开启的事物,业务使用事物都是使用完即时关闭的,而且通过查询tempdb log 文件大小发现
--日志文件使用情况
SELECT s.name,
convert(float,s.size) * CONVERT(float,8) / 1024.0 AS [初始大小MB],
convert(float,i.size) * (8192.0/1024.0)/1024.0 as [分配空间MB],
CAST(FILEPROPERTY(s.name, 'SpaceUsed') AS float)* CONVERT(float,8) / 1024.0 AS [使用空间MB]
FROM
sys.master_files AS s ,dbo.sysfiles AS i
WHERE s.name=i.name AND
(s.type = 1 and s.database_id = db_id())
AND s.name = 'templog'
每隔一两秒的样子,日志文件会增加 3~10 MB的使用空间,因为客户使用的大量的临时表,这个导致tempdb 的log 文件增长,奇怪的是为什么 之前的脏页不会被重用,而是要重新分配新的空间? 唯一能解释的是可能有 事物长时间开着导致,但前面我们说过通过跟踪查询,没有发现有长时间的事物开启,所以有事务导致tempdb log 文件持续增加 ,这个原因 就不成立啦;
通过查阅资料发现,在简单恢复模式下 ,当日志已满 70% 数据库引擎会自动触发检查点, 而我们上面所说客户日志分配空间是 70GB ,已经使用了 40GB,所以还不满足触发检查点刷新脏页的条件;而另一种自动触发自动检查点的机制(恢复间隔), 则不适用于tempdb ,为了验证这观点,我做了实验 如下:

在本地设置tempdb log的初始大小 109MB,然后创建一张临时表,再写入数据,看看日志文件的使用情况,
在创建临时表前 先查询下 日志文件的使用情况,使用空间 3.3MB

创建临时表 ,再插入一万条数据

再次查看 tempdb 日志文件的使用情况

这时我们可以 继续插入 数据,但不要超过日志70%的空间 ,这时再次记录下使用空间,因为sqlserver 2012 的默认的检查点时间为3分钟 ,我们等3分钟再看 ,会不会自动触发检查点刷新脏页,把日志使用空间回收,

三分钟后 再查,日志使用空间依旧没有任何变化

如果再插入一万条数据 大概会有 十几MB 的增长,而这时就已经达到 日志70% 使用的条件,会触发检查点去执行,
我们执行下看看 ,#dddd表中已经有8万条数据了


而日志的使用空间,已经因检查点的执行 ,变回为8.5MB的使用空间了。
所以经过本次测试证实之前的观点是对的,那么我后来把客户的 70GB tempdb log 给设小了 ,设成8GB ,观察了一天,日志使用空间始终在6GB以下。
tempdb 日志文件增长的问题的更多相关文章
- SQL Server 日志文件增长原因定位
方法 1.sys.databases; -------------------------------------------------------------------------------- ...
- MS SQL 监控数据/日志文件增长
前几天,在所有数据库服务器部署了监控磁盘空间的存储过程和作业后(MS SQL 监控磁盘空间告警),今天突然收到了两封告警邮件,好吧,存储规划是一方面,但是,是不是要分析一下是什么原因造成磁盘空 ...
- Sharepoint日志文件增长巨大的解决办法/缩小日志/删除日志
前段时间为公司开发部门建立了TFS平台,其中包括WSS3(MOSS07也可,但是如果不是必须,建议使用轻量级的WSS3).TFS建成之后,程序员们用起来都很满意,总监也很关注. 但是今天早上忽然发现连 ...
- 20170712 SQL Server 日志文件收索
-- 1 日志文件增长过快,未进行任务计划截断备份 造成文件过大199G 左右,而可用空间不足8% -- 2 日志备份之前,需要一次完整备份 再进行截断备份 出现可用空间99% 此时可以选择收索数据库 ...
- flume 增量上传日志文件到HDFS中
1.采集日志文件时一个很常见的现象 采集需求:比如业务系统使用log4j生成日志,日志内容不断增加,需要把追加到日志文件中的数据实时采集到hdfs中. 1.1.根据需求,首先定义一下3大要素: 采集源 ...
- 1. 跟踪标记 (Trace Flag) 1117, 1118 文件增长及空间分配方式
跟踪标记:1117 功能: 默认,同一个文件组下的多个文件,如果某个文件没有可用空间,且设置了自动增长,则该文件自动增长,其他文件大小保持不变: 开启后,同一文件组下的多个文件,如果某个文件没有可用空 ...
- tailf 跟踪日志文件
1.命令功能 tailf 跟踪日志文件增长,作用跟tail –f相同.tailf将输出文件的最后10行,然后等待文件增长. 2.语法格式 tailf option file 参数说明 参数 参数说 ...
- SQLSERVER手动增长日志文件和数据文件
原文:SQLSERVER手动增长日志文件和数据文件 SQLSERVER手动增长日志文件和数据文件 手动增长日志文件,实际上就是修改日志文件的大小 size 的单位是MB 下面设置日志文件大小是204 ...
- SQL Server无法收缩日志文件 2 因为逻辑日志文件的总数不能少于 2问题
SQL Server无法收缩日志文件 2 因为逻辑日志文件的总数不能少于 2问题 最近服务器执行收缩日志文件大小的job老是报错 我所用的一个批量收缩日志脚本 USE [master] GO /*** ...
随机推荐
- 详解Javascript中的原型与原型链
目录 知识点 参考资料 结束语 知识点 面向对象编程 我们熟悉的Java和C#里,面向对象的两个基本概念是类class和实例instance,而ES6以前的Javascript并没有设计class. ...
- SHELL用法三(变量及参数设置)
京峰JF2115-Day45上课笔记 1.SHELL编程变量命名规范: 变量分为:系统变量.环境变量.用户变量: 定义变量时使用=赋值,无需通过declare定义变量的类型: 变量赋值时,=前后是不能 ...
- Steve Lin:如何撰写一篇优秀的SIGGRAPH论文
Lin:如何撰写一篇优秀的SIGGRAPH论文" title="Steve Lin:如何撰写一篇优秀的SIGGRAPH论文"> 英文原版 PPT下载:http:// ...
- 关于前端使用JavaScript获取base64图片大小的方法
base64原理 Base64编码要求把3个8位字节(38=24)转化为4个6位的字节(46=24),之后在6位的前面补两个0,形成8位一个字节的形式. 如果剩下的字符不足3个字节,则用0填充,输出字 ...
- 关于apache的几个常见问题
一.安装apache的时候总是不成功,提示:failed to open the winnt service manager 原因:软件安装时与windows7的"用户账户控制"( ...
- JAVA 获取网页源代码保存到本地文件
package httpget; import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundExce ...
- 如何卸载烦人的2007组件,windows提供的解决方案
如何卸载烦人的2007组件:很恶心人各种软件已经手动删除卸载都无法用,不是cd/dvd找不到就是什么msi文件找不到:对于这种恶心的问题,windows提供了如下解决方案:我使用fixit轻松卸载,很 ...
- 添砖加瓦:MySQL分布式部署
1.集群环境 管理节点(MGM):这类节点的作用是管理MySQLCluster内的其他节点,如提供配置数据,并停止节点,运行备份等.由于这类节点负责管理其他节点的配置,应该在启动其他节点之前启动这类 ...
- Ubuntu14.04下GAMIT10.6的安装
#安装步骤将ubuntu切换到root用户权限 1 $sudo -s ##安装必要软件 1 2 3 4 5 $ apt-get install gcc $ apt-get install gfortr ...
- All Tips
Outlook分享心得 这是在爱奇艺的一场Outlook分享会上我记录的笔记. Read More 分享一点"关于应届生如何写简历"的人生经验 应届生如何写好一份求职简历是一件重要 ...