SQL Server 2008 R2-SP2 上的 Tempdb 日志文件不断增长。使用临时表的挂起插入语句可能是原因吗?

Pat*_*Pat 5 sql-server transaction-log

我刚刚开始担任 DBA 的新工作。突然间,我们开始收到有关磁盘空间的警报。当我查看时,我发现 tempdb 日志文件在不断增长。有一个针对它的活跃事务正在运行。我检查了查询,它使用的是临时表。从45分钟开始,事情就毫无进展了。我尝试了很多事情,包括这些作为最后的手段。

use tempdb
GO
DBCC FREEPROCCACHE -- clean cache
DBCC DROPCLEANBUFFERS -- clean buffers
DBCC FREESYSTEMCACHE ('ALL') -- clean system cache
DBCC FREESESSIONCACHE -- clean session cache
Run Code Online (Sandbox Code Playgroud)

但这根本没有帮助。我还杀死了卡住的插入件。看来这并没有超出正常流程。最后我不得不紧急中断几分钟并重新启动 SQL 服务。关于我可能错过的内容有什么建议吗?

Mar*_*lli 5

关于这个问题:

如何识别哪个查询正在填充 tempdb 事务日志?

您将能够以不同的方式看到更多的技术信息,了解为什么会发生这种情况以及如何处理。

下面是一个脚本,我必须检查临时数据库中填充的内容。这可能是您探索的一个很好的起点。

use tempdb

SELECT top 100
tsu.internal_objects_alloc_page_count,
tsu.user_objects_alloc_page_count,
es.host_name , 
es.login_name ,
es.program_name,
st.dbid as QueryExecContextDBID, 
DB_NAME(st.dbid) as QueryExecContextDBNAME, 
st.objectid as ModuleObjectId,

SUBSTRING(st.text, er.statement_start_offset/2 + 1,
          (CASE WHEN er.statement_end_offset = -1 THEN 
               LEN(CONVERT(nvarchar(max),st.text)) * 2 ELSE 
               er.statement_end_offset 
           END - er.statement_start_offset)/2) as Query_Text,

tsu.session_id ,
tsu.request_id, 
tsu.exec_context_id,

(tsu.user_objects_alloc_page_count 
  - tsu.user_objects_dealloc_page_count) as OutStanding_user_objects_page_counts,

(tsu.internal_objects_alloc_page_count 
 - tsu.internal_objects_dealloc_page_count) as OutStanding_internal_objects_page_counts,

er.start_time, 
er.command, 
er.open_transaction_count, 
er.percent_complete, 
er.estimated_completion_time, 
er.cpu_time, 
er.total_elapsed_time, 
er.reads,er.writes, 
er.logical_reads, 
er.granted_query_memory

FROM sys.dm_db_task_space_usage tsu 
inner join sys.dm_exec_requests er 
        ON (     tsu.session_id = er.session_id 
             and tsu.request_id = er.request_id) 

inner join sys.dm_exec_sessions es 
       ON ( tsu.session_id = es.session_id ) 

CROSS APPLY sys.dm_exec_sql_text(er.sql_handle) st

WHERE (tsu.internal_objects_alloc_page_count 
       + tsu.user_objects_alloc_page_count) > 0

ORDER BY (tsu.user_objects_alloc_page_count 
          - tsu.user_objects_dealloc_page_count)
        +(tsu.internal_objects_alloc_page_count 
           - tsu.internal_objects_dealloc_page_count) 

DESC
Run Code Online (Sandbox Code Playgroud)