—教训深刻—SQL Server大约TempDB使用
场景现象
中午查询了流水,因未与业务人员沟通好。忘了删选条件,导致TempDB不能分配空间,SQL Server高负载执行。
错误分析
我们来看看错误日志:
再来看看TempDB自增长记录:
|
事件 |
逻辑文件名称 |
启动时间 |
持续时间(毫秒) |
大小变化(MB) |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 13:01:51 |
23 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 13:01:27 |
30 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 13:01:03 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 13:00:42 |
40 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 13:00:18 |
20 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:59:55 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:59:32 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:59:09 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:58:47 |
33 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:58:24 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:58:00 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:57:36 |
30 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:57:12 |
26 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:56:48 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:56:24 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:56:01 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:55:36 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:55:12 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:54:49 |
30 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:54:24 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:53:59 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:53:37 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:53:14 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:52:53 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:52:30 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:52:05 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:51:43 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:51:21 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:50:59 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:50:36 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:50:13 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:49:50 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:49:26 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:49:04 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:48:42 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:48:19 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:47:56 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:47:33 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:47:11 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:46:49 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:46:26 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:46:02 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:45:40 |
60 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:45:16 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:44:54 |
16 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:44:32 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:44:09 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:43:47 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:43:25 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:43:03 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:42:41 |
3 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:42:20 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:41:56 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:41:35 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:41:11 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:40:50 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:40:29 |
40 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:40:09 |
30 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:39:45 |
23 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:39:23 |
26 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:39:02 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:38:39 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:38:17 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:37:54 |
13 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:37:32 |
16 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:37:10 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:36:49 |
6 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:36:27 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:36:05 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:35:44 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:35:22 |
10 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:34:59 |
43 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_1 |
2014/4/17 12:34:37 |
50 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_2 |
2014/4/17 12:34:08 |
23 |
1,024.00 |
|
数据文件自己主动增长 |
tempdev_0 |
2014/4/17 12:33:35 |
20 |
1,024.00 |
导致原因
查询语句未指定删选条件,语句例如以下:
--得到流水,因数据敏感问题,已将字段使用’xx’取代。
IF EXISTS (SELECT *
FROM tempdb..sysobjects
WHERE id = Object_id(N'tempdb..#t_scfw')
AND type = 'U')
DROP TABLE #t_scfw; IF NOT EXISTS (SELECT *
FROM tempdb..sysobjects
WHERE id = Object_id(N'tempdb..#t_scfw')
AND type = 'U')
SELECT tsvr.*,
bsl.xx AS xxx,
bsl.xx,
bsl.xx
INTO #t_scfw
FROM #t1 AS tsvr
JOIN t2 AS bsl
ON tsvr.xx = bsl.xx
AND tsvr.xx = bsl.xx
AND tsvr.xx = bsl.xx
AND tsvr.xx = bsl.xx
AND bsl.xx > 0;
总结
因为tempdb是存储在SSD上。且总大小为270G。
所以,在显式使用暂时表时一定要注意数据大小。
避免把tempdb空间耗尽,影响整个SQLServer的正常执行。好在设置了tempdb的最大空间。而且最大空间小于SSD硬盘的最大容量,不然server的盘就会挂掉,从而导致server宕机,多么痛的领悟!
切忌犯如此低级错误,作下此文提醒和鞭策自己,凡事三思而后行!
Good Luck!
版权声明:本文博客原创文章,博客,未经同意,不得转载。
—教训深刻—SQL Server大约TempDB使用的更多相关文章
- SQL Server中tempdb的管理
原文:SQL Server中tempdb的管理 资料来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive/tags/tempdb/ ht ...
- 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空间
原文:监测谁用了SQL Server的Tempdb空间 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/02/11/sql-server-tempdb. ...
- SQL Server中tempdb的management
对<SQL Server中tempdb的management>的一些更正和补充 对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这 ...
- [转]如何监测谁用了SQL Server的Tempdb空间
Tempdb 系统数据库是一个全局资源,供连接到 SQL Server 实例的所有用户使用.在现在的SQL Server里,其使用频率可能会超过用户的想象.如果Tempdb空间耗尽,许多操作将不能完成 ...
- 对《SQL Server中tempdb的management》的一些更正和补充
对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这篇文章:SQL Server中tempdb的management 发现里面有些内容不是很准确 文 ...
- sql server转移tempdb数据库的物理存放位置
转移前将原来的文件备份一下 将 tempdb 从其在磁盘上的当前位置移动到其他磁盘位置.由于每次启动 MSSQLSERVER 服务时都会重新创建 tempdb,因此不需要从物理意义上移动数据和日志 ...
- SQL server performance - tempdb
When tempdb is used? User objects: User-defined tables and indexes System tables and indexes Global ...
随机推荐
- hdu4283(区间dp)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=4283 题意:有一个队列,每个人有一个愤怒值D,如果他是第K个上场,不开心指数就为(K-1)*D.但是边 ...
- hdu4151(二分)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4151 题意:找出比n小的没有重复数字的总个数,例如12以内11不符合,1~10都符合. 分析:直接利用 ...
- HTML解析HtmlAgilityPack
原文:HTML解析HtmlAgilityPack //解析页面源代码 Uri surl = new Uri(url); Uri uriCategory = ...
- C# 使用Tuple传递多个参数
Tuple是基于.NET Framework 4.0 及以上版本才有的.微软称它为元组,如果有三个参数那就是三元组.如 Tuple(T1, T2, T3) Tuple的命名空间在 System 很短吧 ...
- Cantor的数表 【找规律】
小俞同学,近期勤学苦练数学,对一种数表产生了兴趣. 数表例如以下: 1/1 1/2 1/3 1/4 1/5 2/1 2/2 2/3 2/4 3/1 3/2 3/3 4/1 4/2 5/1 她冥思苦相了 ...
- Oracle基础(五)pl/sql进阶(分页过程)
编写分页过程 通过pl/sql实现分页过程,再该过程中由简单到难一步步深入,目的在于通过该案例熟悉pl/sql的各种存储过程,包,游标.怎样在java中调用等内容的学习. 1.无返回值 ...
- windows phone (15) UI变换上
原文:windows phone (15) UI变换上 在wp中只要是继承自UIElement 的任何对象都可以应用变换,当然包含Textblock,Rectangle等所有的元素,下面我们使用Tex ...
- Linux命令对应的全称解释(转)
Filesystem Hierarchy Standard(FHS) /:根目录,所有的目录.文件.设备都在/之下,/就是Linux文件系统的组织者,也是最上级的领导者. /bin:bin 就是二进 ...
- Keepalived 配置和使用
keepalived主要用作RealServer的健康状态检查以及LoadBalance主机和BackUP主机之间failover的实现.keepalived主要目的在于,其自身启动一个服务,能够实现 ...
- 冒泡排序java
先对冒泡排序做一个简单的解释,然后是代码的实现.解释出资<java的数据结构和算法>,大家可以看看. 排序类: package com.dxx.order; public class Bu ...