SQLServer中Tempdb空间异常增长及占用非常大该怎么办-创新互联

SQLServer中Tempdb空间异常增长及占用非常大该怎么办,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

创新互联建站是一家以网络技术公司,为中小企业提供网站维护、成都网站建设、成都网站设计、网站备案、服务器租用、域名申请、软件开发、微信平台小程序开发等企业互联网相关业务,是一家有着丰富的互联网运营推广经验的科技公司,有着多年的网站建站经验,致力于帮助中小企业在互联网让打出自已的品牌和口碑,让企业在互联网上打开一个面向全国乃至全球的业务窗口:建站沟通电话:18982081108

一、问题现象

    我们一套量产SQLServer,在半夜的时候发出磁盘空间不足告警,我登上去检查后,发现 tempdb 已经超过500GB。

二、原因解析

    跟AP user沟通后,AP user告诉我们,由于AP逻辑出现问题,导致tempdb异常增长。

三、解决方法

    1、如果可以重启 SQL Server,tempdb 会自动重新创建,从而使 tempdb 回归到初始大小。但是量产环境尽量不要重启,除非万不得已。

    2、直接收缩 tempdb(但是始终不成功)。

    (1)命令

USE [tempdb]
GO

DBCC SHRINKFILE (N'tempdb.mdf' , 0, TRUNCATEONLY)  --释放所有可用空间
GO

DBCC SHRINKFILE (N'tempdb.mdf' , 500) -- 收缩datafile到 500MB

GO

DBCC SHRINKFILE (N'templog.ldf' , 10) -- 收缩日志到 10MB

GO 

(2)图形化界面

3、如果出现无法收缩tempdb的情况,可先使用以下方式处理,再收缩。

SQL Server 2005 及后续版本为了增强 tempdb 的性能,会缓存一些 IAM 页,以备将来重新使用这些页面。在这种情况下,必须首先释放 IAM 页,才能释放其对应的页面。因此,通过 DBCC FREESYSTEMCACHE,从所有缓存中释放所有未使用的缓存条目,然后再收缩 tempdb 。

USE [tempdb]
GO

DBCC FREESYSTEMCACHE ('ALL')

GO

DBCC SHRINKFILE (N'tempdb.mdf' , 500)

GO

看完上述内容,你们掌握SQLServer中Tempdb空间异常增长及占用非常大该怎么办的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联-成都网站建设公司行业资讯频道,感谢各位的阅读!


当前标题:SQLServer中Tempdb空间异常增长及占用非常大该怎么办-创新互联
本文URL:http://bzwzjz.com/article/ehpco.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 公司网站建设 网站设计 手机网站建设套餐 成都网站制作 成都网站建设 成都网站设计 重庆网站建设 成都网站制作 成都响应式网站建设 网站设计 网站建设方案 营销型网站建设 成都网站制作 成都网站制作 手机网站制作 网站设计 盐亭网站设计 成都网站制作 重庆电商网站建设 定制网站设计 成都网站制作 重庆企业网站建设