sql-server – 在生产环境中收缩Tempdb的最佳实践

sql Server 2008中缩小临时数据库时使用的最佳做法是什么?

使用以下内容有风险吗?

use tempdb
GO

DBCC FREEPROCCACHE -- clean cache
DBCC DROPCLEANBUFFERS -- clean buffers
DBCC FREESYstemCACHE ('ALL') -- clean system cache
DBCC FREESESSIONCACHE -- clean session cache
DBCC SHRINKDATABASE(tempdb,10); -- shrink tempdb
dbcc shrinkfile ('tempdev') -- shrink db file
dbcc shrinkfile ('templog') -- shrink log file
GO

-- report the new file sizes
SELECT name,size
FROM sys.master_files
WHERE database_id = DB_ID(N'tempdb');
GO

解决方法

最佳做法是主动监视Tempdb的正常使用情况并相应地设置大小.
如果这是Tempdb已经增长到这样大小并且它是PROD env的一种情况,我将在每周维护期间重新启动sql Server服务.在Tempdb之后会回到其配置的大小.

只要没有使用Tempdb,缩小文件就可以了,否则由于阻塞和死锁,现有的事务可能会从性能的角度受到影响.

清理过程缓存,缓冲区缓存等将对数据库性能本身产生负面影响,直到不重新创建它们.我不会在PROD上这样做.

希望有所帮助!

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...