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 服务。关于我可能错过的内容有什么建议吗?
关于这个问题:
您将能够以不同的方式看到更多的技术信息,了解为什么会发生这种情况以及如何处理。
下面是一个脚本,我必须检查临时数据库中填充的内容。这可能是您探索的一个很好的起点。
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)