SQLServer的tempdb暴增導致磁碟消耗的處理方案
先查長事務:
SELECT transaction_id,session_id
FROM sys.dm_tran_active_snapshot_database_transactions
ORDER BY elapsed_time_seconds DESC;
再看這些會話執行了多久:
SELECT
es.session_id,
--database_name ='HKERP',
login_name,
er.status,
wait_type,
individual_query = SUBSTRING (qt.text, er.statement_start_offset/2, (CASE WHEN er.statement_end_offset = -1 THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2 ELSE er.statement_end_offset END - er.statement_start_offset)/2),
parent_query = qt.text,
program_name,
host_name,
nt_domain,
start_time
FROM
sys.dm_exec_requests er
INNER JOIN sys.dm_exec_sessions es ON er.session_id = es.session_id
CROSS APPLY sys.dm_exec_sql_text(er.sql_handle)as qt
WHERE
es.session_id > 50
AND es.session_Id NOT IN (@@SPID)
ORDER BY
1, 2
看看有沒阻塞:
SELECT s.loginame
,[Individual Query] = SUBSTRING (qr.text,qs.statement_start_offset/2,
(CASE WHEN qs.statement_end_offset = -1 THEN LEN(CONVERT(NVARCHAR(MAX), qr.text)) * 2
ELSE qs.statement_end_offset
END - qs.statement_start_offset)/2)
,qs.session_id ,s.counts AS [程式個數],qs.status ,qs.blocking_session_id
,qs.wait_type ,qs.wait_time ,qs.wait_resource
,qs.transaction_id
FROM SYS.DM_EXEC_REQUESTS qs (nolock)
LEFT JOIN (
SELECT spid,MAX(loginame)AS loginame,COUNT(0)AS counts FROM SYS.SYSPROCESSES (nolock) GROUP BY spid
) s ON qs.session_id=s.spid
OUTER APPLY SYS.DM_EXEC_SQL_TEXT(qs.sql_handle) AS qr
WHERE qs.status = N'suspended'
--and s.loginame<>''
ORDER BY qs.wait_time DESC
--查詢阻塞源頭v3.0
SELECT SP.spid
,CASE WHEN ST1.text IS NULL THEN ST2.text
ELSE SUBSTRING (ST1.text,SR.statement_start_offset/2,
(
CASE WHEN SR.statement_end_offset = -1 THEN LEN(CONVERT(NVARCHAR(MAX), ST1.text)) * 2
ELSE SR.statement_end_offset
END - SR.statement_start_offset)/2
)
END AS [T-sql]
,SP.loginame
,DB_NAME(SP.dbid) AS [db_name]
,SP.open_tran,SP.hostname,SP.program_name,SP.waitresource,SP.*
FROM SYS.SYSPROCESSES SP (nolock)
LEFT JOIN SYS.DM_EXEC_REQUESTS SR (nolock) ON SP.spid=SR.session_id
LEFT JOIN SYS.DM_EXEC_CONNECTIONS SC (nolock) ON SP.spid=SC.session_id
OUTER APPLY SYS.DM_EXEC_SQL_TEXT(SC.most_recent_sql_handle) AS ST2
OUTER APPLY SYS.DM_EXEC_SQL_TEXT(SR.sql_handle) AS ST1
WHERE SP.spid IN
(
SELECT BLOCKED FROM SYS.SYSPROCESSES (nolock) WHERE BLOCKED<>0 and lastwaittype<>'MISCELLANEOUS'
)
AND SP.BLOCKED=0
殺了阻塞源,或者是長事務,一般就能解決問題了。
同時對比tempdb前後的使用情況。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22996654/viewspace-2998570/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 關於SQLServer的tempdb的資料檔案暴增問題(1)SQLServer
- OGG相關的CPATURE導致SYSAUX表空間異常暴增處理UX
- tempdb資料檔案暴增分析
- tempdb日誌檔案暴增分析
- 磁碟IO故障導致的SQLServer資料庫無法寫入SQLServer資料庫
- 【MySQL】一條SQL使磁碟暴漲並導致MySQL CrashMySql
- Sqlserver定位哪些物件和哪些會話哪些sql語句消耗了tempdbSQLServer物件會話
- 併發請求導致的業務處理安全風險及解決方案求導
- ORACLE SQL調優之統計資訊缺失導致的邏輯讀暴增OracleSQL
- 如何處理快取導致的無效曝光快取
- 【問題處理】因ASM磁碟組空間不足導致資料庫例項無法啟動的故障處理ASM資料庫
- RDS最佳實踐(五)—Mysql大欄位的頻繁更新導致binlog暴增MySql
- 系統crash掉導致ORA-00600的處理
- Oracle全部索引丟失導致的效率問題處理Oracle索引
- crontab導致CPU異常的問題分析及處理
- asmcmd對磁碟組的處理ASM
- 【SQLServer】Tempdb空間異常增長,空間佔用非常大SQLServer
- 一個導致JVM實體記憶體消耗大的BugJVM記憶體
- 使用資料庫處理併發可能導致的問題資料庫
- raid磁碟陣列OFFLINE後的應急處理方案AI陣列
- MySQL 磁碟空間滿導致表空間相關資料檔案損壞故障處理MySql
- idea外掛報錯導致不能啟動的處理技巧Idea
- sqlldr標準輸出未處理導致批處理掛起問題SQL
- 如何在 Swift 中優雅的處理閉包導致的迴圈引用Swift
- sqlserver 針對預處理sql傳入引數的處理方式SQLServer
- 【RAC】處理因ons導致CPU使用率過高的問題
- 歸檔日誌滿導致的資料庫掛起故障處理資料庫
- 【RMAN】“壞塊”導致RMAN備份不成功的RMAN處理方法
- 磁碟處理函式函式
- SqlServer——字串處理函式SQLServer字串函式
- 如何解決tempdb 增長過大的問題
- 故障分析 | MySQL convert 函式導致的字符集報錯處理MySql函式
- 磁碟IO過高時的處理辦法
- 儲存崩潰導致資料丟失如何處理
- SQLServer如何釋放tempdb臨時表空間SQLServer
- 磁碟損壞導致資料檔案丟失的恢復
- windbg分析一次大查詢導致的記憶體暴漲記憶體
- 歸檔日誌滿導致的資料庫掛起故障處理【轉載】資料庫