操作系统是Windows2008R2 ,数据库是SQL2008R2 64位

64G内存,16核CPU

硬件配置还是比较高的,他说服务器运行的是金蝶K3软件,数据库实例里有多个数据库

现象

他说是这几天才出现的,而且在每天的某一个时间段才会出现CPU占用高的情况

内存占用不太高,只占用了30个G

CPU占用100%

排查方向

一般排查都是用下面的脚本,一般会用到三个视图sys.sysprocesses ,dm_exec_sessions ,dm_exec_requests

1 USE master

2 GO

3 --如果要指定数据库就把注释去掉

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

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

看一下当前的数据库用户连接有多少

然后使用下面语句看一下各项指标是否正常,是否有阻塞,这个语句选取了前10个最耗CPU时间的会话

1 SELECT TOP 10

2 [session_id],

3 [request_id],

4 [start_time] AS '开始时间',

5 [status] AS '状态',

6 [command] AS '命令',

7 dest.[text] AS 'sql语句',

8 DB_NAME([database_id]) AS '数据库名',

9 [blocking_session_id] AS '正在阻塞其他会话的会话ID',

10 [wait_type] AS '等待资源类型',

11 [wait_time] AS '等待时间',

12 [wait_resource] AS '等待的资源',

13 [reads] AS '物理读次数',

14 [writes] AS '写次数',

15 [logical_reads] AS '逻辑读次数',

16 [row_count] AS '返回结果行数'

17 FROM sys.[dm_exec_req

好文推荐

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。