场景现象

中午查询了流水,因未与业务人员沟通好。忘了删选条件,导致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使用的更多相关文章

  1. SQL Server中tempdb的管理

    原文:SQL Server中tempdb的管理 资料来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive/tags/tempdb/ ht ...

  2. SQL Server中TempDB管理(version store的逻辑结构)

    原文:SQL Server中TempDB管理(version store的逻辑结构) 原文来自: http://blogs.msdn.com/b/sqlserverstorageengine/arch ...

  3. SQL Server中TempDB管理(版本存储区的一个example)

    原文:SQL Server中TempDB管理(版本存储区的一个example) 原文来自: http://blogs.msdn.com/b/sqlserverstorageengine/archive ...

  4. 监测谁用了SQL Server的Tempdb空间

    原文:监测谁用了SQL Server的Tempdb空间 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/02/11/sql-server-tempdb. ...

  5. SQL Server中tempdb的management

    对<SQL Server中tempdb的management>的一些更正和补充   对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这 ...

  6. [转]如何监测谁用了SQL Server的Tempdb空间

    Tempdb 系统数据库是一个全局资源,供连接到 SQL Server 实例的所有用户使用.在现在的SQL Server里,其使用频率可能会超过用户的想象.如果Tempdb空间耗尽,许多操作将不能完成 ...

  7. 对《SQL Server中tempdb的management》的一些更正和补充

    对<SQL Server中tempdb的management>的一些更正和补充 前几天看了这篇文章:SQL Server中tempdb的management 发现里面有些内容不是很准确 文 ...

  8. sql server转移tempdb数据库的物理存放位置

    转移前将原来的文件备份一下   将 tempdb 从其在磁盘上的当前位置移动到其他磁盘位置.由于每次启动 MSSQLSERVER 服务时都会重新创建 tempdb,因此不需要从物理意义上移动数据和日志 ...

  9. SQL server performance - tempdb

    When tempdb is used? User objects: User-defined tables and indexes System tables and indexes Global ...

随机推荐

  1. Effective C++ -- 构造析构赋值运算

    05.了解C++默默编写并调用哪些函数 编译产生的析构函数时non-virtual,除非这个类的基类析构函数为virtual 成员变量中有引用和const成员时,无法自己主动生成copy assign ...

  2. IDEA系统提示中文乱码问题及解决

    近期要切换到IDEA开发, 在输出界面发现打印小方格, 或者乱码, 是由于字体不支持中文, 选择一个支持中文的就正常了.(由于IDEA在国内下载错误信息会用中文显示. 而之前Eclipse错误都是英文 ...

  3. Codeforces Round #246 (Div. 2) D. Prefixes and Suffixes(后缀数组orKMP)

    D. Prefixes and Suffixes time limit per test 1 second memory limit per test 256 megabytes input stan ...

  4. SQL Syscolumns

    每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行.该表位于每个数据库中. 列名 数据类型 描述 name sysname 列名或过程参数的名称. id int 该列所属的表对象 I ...

  5. SE 2014 年4月21日(一)

    如图配置 网络中存在四个自治系统,设备之间要求建立BGP对等体关系,发布BGP路由,使得全网BGP路由相互通讯. 要求 1. 由于AS 200中的路由信息频繁抖动,所以AS 100 和 AS 300 ...

  6. linux编程进阶书推荐APUE,UNP

    编程进阶这里强烈推荐<unix环境高级编程>(简称APUE)和<unix网络编程>(简称UNP),这两本书可是经典中的经典啊,作 者是大名鼎鼎的 W.Richard Steve ...

  7. cocostudio内存释放

    在使用cocostudio时,在释放内存时能够这样做: 在onExit()方法里加入例如以下: void LoadLayer::onExit() { // 释放本对象自己 removeFromPare ...

  8. Java流的理解

    最近做了一下Socket编程,其中有socket.getInputStream和socket.getOutputStream的问题. 想传输文件,感觉应该用FileInputStream和FileOu ...

  9. UVa 884 - Factorial Factors

    题目:输出n!中素数因数的个数. 分析:数论.这里使用欧拉筛法计算素数,在计算过程中求解就可以. 传统筛法是利用每一个素数,筛掉自己的整数倍: 欧拉筛法是利用当前计算出的全部素数,乘以当前数字筛数: ...

  10. Golang在Linux环境下的POSIX风格socket编程

    这里给出一个服务端和client,服务端能够接受多个连接,而且利用Go的杀手特性go和channel来替代select进行数据的接收. 服务端: package main import ( " ...