在SQL Server中,会话的状态有运行(Running)、睡眠(Sleeping)、休眠(Dormant)、Preconnect 等状态,有时候你会在数据库中看到很多会话处于睡眠(Sleeping)状态,那么这些睡眠(Sleeping)状态的会话会消耗CPU、Memory资源吗?如果消耗资源的话,那么sleeping会话具体消耗多少内存资源呢? 另外它会影响数据库性能吗?
首先,处于睡眠(Sleeping)状态的会话意味着当前没有运行任何请求。这样也意味着这种状态的会话是不会消耗CPU资源的,那么它是否消耗内存资源呢?答案是会,它会保留了一定数量的内存,用于保存与会话相关的结构。 这包括会话上下文等信息, 关于每个处于睡眠状态会话消耗的内存具体大小,可以使用下面脚本查看睡眠(Sleeping)状态会话消耗的内存(不确定其值的准确性,文末有介绍):
SELECT
s.session_id
, s.status
, s.last_request_start_time
, s.memory_usage*8 AS memory_usage_kb
, t.task_state
, s.host_name
, s.program_name
, s.transaction_isolation_level
--, s.open_transaction_count
FROM sys.dm_exec_connections AS c
JOIN sys.dm_exec_sessions AS s ON
s.session_id = c.session_id
LEFT JOIN sys.dm_os_tasks AS t ON
t.session_id = s.session_id
WHERE s.status='sleeping'
ORDER BY
s.memory_usage DESC;