SQLServer中Tempdb空间异常增长及占用非常大该怎么办
SQLServer中Tempdb空间异常增长及占用非常大该怎么办,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
一、问题现象
我们一套量产SQLServer,在半夜的时候发出磁盘空间不足告警,我登上去检查后,发现 tempdb 已经超过500GB。
二、原因解析
跟AP user沟通后,AP user告诉我们,由于AP逻辑出现问题,导致tempdb异常增长。
三、解决方法
1、如果可以重启 SQL Server,tempdb 会自动重新创建,从而使 tempdb 回归到初始大小。但是量产环境尽量不要重启,除非万不得已。
2、直接收缩 tempdb(但是始终不成功)。
(1)命令
USE [tempdb] DBCC SHRINKFILE (N'tempdb.mdf' , 0, TRUNCATEONLY) --释放所有可用空间 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] DBCC FREESYSTEMCACHE ('ALL') GO DBCC SHRINKFILE (N'tempdb.mdf' , 500) GO |
看完上述内容,你们掌握SQLServer中Tempdb空间异常增长及占用非常大该怎么办的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注蜗牛博客行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo99@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
评论