SQLSERVER排查CPU占用高的情況

最近發(fā)現(xiàn)SQLserver進程占用CPU的很大,導(dǎo)致應(yīng)用程序部分程序打開緩慢,

把sqlserver服務(wù)重新啟動以后,情況好轉(zhuǎn),但是過一段時間或者一會,cpu占用有大了。

最后排除發(fā)現(xiàn)是網(wǎng)絡(luò)內(nèi)某個機器訪問sql過大造成的,怎么找到這個具體的機器呢

利用下面語句:

USE master

GO

----如果要指定數(shù)據(jù)庫就把注釋去掉

SELECT * FROM sys.sysprocesses WHERE spid>50 AND DB_NAME([dbid])='JHLZB'

SELECT COUNT(*) FROM sys.dm_exec_sessions WHERE session_id>50

看一下當(dāng)前的數(shù)據(jù)庫用戶連接有多少,都是什么機器連接的,哪個機器連接消耗cpu大,找到具體的機器處理。

然后使用下面語句看一下各項指標(biāo)是否正常,是否有阻塞,這個語句選取了前10個最耗CPU時間的會話

SELECT TOP 10

[session_id],

[request_id],

[start_time] AS '開始時間',

[status] AS '狀態(tài)',

[command] AS '命令',

dest.[text] AS 'sql語句',

DB_NAME([database_id]) AS '數(shù)據(jù)庫名',

[blocking_session_id] AS '正在阻塞其他會話的會話ID',

[wait_type] AS '等待資源類型',

[wait_time] AS '等待時間',

[wait_resource] AS '等待的資源',

[reads] AS '物理讀次數(shù)',

[writes] AS '寫次數(shù)',

[logical_reads] AS '邏輯讀次數(shù)',

[row_count] AS '返回結(jié)果行數(shù)'

FROM sys.[dm_exec_requests] AS der

CROSS APPLY

sys.[dm_exec_sql_text](der.[sql_handle]) AS dest

WHERE [session_id]>50 AND DB_NAME(der.[database_id])='JHLZB'?

ORDER BY [cpu_time] DESC


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容