在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;

使用这个这个脚本查出,发现处于睡眠(Sleeping)状态会话消耗的内存有很多情况: 0KB、16KB、24KB、32KB、40KB、.....216KB.  似乎没有什么规律,当然以32KB、40KB居多。官方文档关于这方面的介绍几乎没有,仅仅在“Memory Used by SQL Server Objects Specifications”中有部分介绍,如下所示:

下表列出 SQL Server 中不同对象所用内存的大致数值。列出的数值为估计值,具体取决于环境和创建对象的方式。SQL Server 2005 管理某些项的方式与早期版本存在显著差异。

SQL Server 2000

SQL Server 2005

SQL Server 2008

每个所有者 64 字节 + 32 字节

每个所有者 64 字节 + 32 字节

每个所有者 64 字节 + 32 字节

打开的数据库

每个文件 3924 字节 + 1640 字节,每个文件组 336 字节

不适用于 SQL Server 2005

不适用于 SQL Server 2008

打开的对象

对象中每个打开的索引 256 字节 + 1724 字节

不适用于 SQL Server 2005

不适用于 SQL Server 2008

用户连接

12 KB + (3 * network_packet_size)

约为 (3 * network_packet_size + 94 KB)

约为 (3 * network_packet_size + 94 KB)

网络数据包大小是表格格式数据流 (TDS) 数据包的大小,该数据包用于应用程序和 SQL Server 数据库引擎之间的通信。默认的数据包大小为 4 KB,由“网络数据包大小”配置选项控制。

启用多个活动的结果集时,用户连接约为 (3 + 3 * num_logical_connections) * network_packet_size + 94 KB。

但是在SQL Server 2008之后的文档,没有看到这方面内容的介绍。在SQL Server 2005、SQL Server 2008数据库中测试发现(使用最上面的脚本)memory_usage大小为16KB、24KB,远小于94KB,这个文档和测试结果也一度让我怀疑sys.dm_exec_sessions这个DMV视图中memory_usage字段计算Sleeping会话消耗内存的准确性。很遗憾,官方资料关于memory_usage的介绍仅为:Number of 8-KB pages of memory used by this session. Is not nullable. 不过,有点可以确认的是:Sleeping状态的会话消耗的内存资源真的很少。基本上对数据库性能影响很小。

参考资料:

https://docs.microsoft.com/zh-cn/previous-versions/sql/sql-server-2008-r2/aa337559(v=sql.105)

https://social.msdn.microsoft.com/Forums/sqlserver/en-US/62d19c9e-7ccb-4e1b-a18f-f249c23f0376/sleeping-spids-consume-cpu-and-memory-?forum=sqlgetstarted

https://docs.microsoft.com/en-us/sql/relational-databases/system-dynamic-management-views/sys-dm-exec-sessions-transact-sql?view=sql-server-2017

SQL Server Sleeping会话占用内存资源浅析?的更多相关文章

  1. SQL Server 2008 R2占用内存越来越大两种解决方法

    SQL Server 2008 R2运行越久,占用内存会越来越大. 第一种:有了上边的分析结果,解决方法就简单了,定期重启下SQL Server 2008 R2数据库服务即可,使用任务计划定期执行下边 ...

  2. SQL Server 2008 R2占用内存越来越大解决方法

    最近开发sql server数据库项目的过程中发现了这么一个问题,后台网站内存占用95%,通过任务管理器查看占内存的进程sqlserver.exe,是因为SQL Server 2008 R2运行越久, ...

  3. SQL Server 2014里的IO资源调控器

    在本文中,我们将来看看SQL Server 2014在资源调控器方面增加了哪些新的功能.资源调控器(Resource Governor)是从SQL Server 2008开始出现的一项功能.它是用于管 ...

  4. 如何使用 DBCC MEMORYSTATUS 命令来监视 SQL Server 2005 中的内存使用情况

    https://technet.microsoft.com/en-us/solutionaccelerators/dd537566.aspx 注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完 ...

  5. 《Troubleshooting SQL Server》读书笔记-内存管理

    自调整的数据库引擎(Self-tuning Database Engine) 长期以来,微软都致力于自调整(Self-Tuning)的SQL Server数据库引擎,用以降低产品的总拥有成本.从SQL ...

  6. 显示SQL Server分配的全部内存

    1.在sqlserver 中建立查询 2.执行 DBCC MEMORYSTATUS 在Windows Server 2000/2003任务管理器中,“内存使用”这个字段是显示工作区分配的内存.一个进程 ...

  7. 查看SQL Server当前会话的隔离级别

    查看SQL Server当前会话的隔离级别 DBCC USEROPTIONS

  8. sql server 性能调优之 资源等待内存瓶颈的三种等待类型

    一.概述 这篇介绍Stolen内存相关的主要三种等待类型以及对应的waittype编号,CMEMTHREAD(0x00B9),SOS_RESERVEDMEMBLOCKLIST(0x007B),RESO ...

  9. sql server 性能调优之 资源等待SOS_SCHEDULER_YIELD

    一.概念 SOS_SCHEDULER_YIELD等待类型是一个任务自愿放弃当前的资源占用,让给其他任务使用.   这个等待类型与CPU有直接关系,与内存与也有间接关系,与CPU有关系是因为在sql s ...

随机推荐

  1. JSP环境探针-当前电脑所有系统参数

    1 <%@ page contentType="text/html;charset=gb2312" %> <%@ page import="java.u ...

  2. 【236】◀▶IEW-Unit01

    Unit 1  Fast Food I.动名词的用法 Doing(V-ing) 核心思想:词性是名词,作用是动词 1. 名词 3)主语(句首) 保护环境是我们每个人的责任. Protecting th ...

  3. web性能并发测试工具(转)

    导读:随着Web 2.0技术的迅速发展,许多公司都开发了一些基于Web的网站服务,通常在设计开发Web应用系统的时候很难模拟出大量用户同时访问系统的实际情况,因此,当Web网站遇到访问高峰时,容易发生 ...

  4. 条款32:确定你的public继承塑模出is-a的关系

    Make sure public inheritance models "is –a " 如果令clsss D 以public的形式继承class B,你便是告诉编译器说,每一个类 ...

  5. JAVA学习笔记——(三)

    今日内容介绍 1.引用类型变量的创建及使用 2.流程控制语句之选择语句 3.流程控制语句之循环语句 4.循环高级 01创建引用类型变量公式 * A: 创建引用类型变量公式 * a: 我们要学的Scan ...

  6. ACM-ICPC2018徐州网络赛 BE, GE or NE(对抗搜索+博弈+记忆化)

    BE, GE or NE 23.58% 1000ms 262144K   In a world where ordinary people cannot reach, a boy named &quo ...

  7. 英语学习Start

  8. MATLAB---make与makefile简单介绍

    1 make.makefile概述 makefile定义了一系列的规则,来规定哪些部分先编译,哪些部分后编译,写好makefile以后,只需一个make命令就可以让整个工程完全自动编译,所以简单的说, ...

  9. IT兄弟连 Java语法教程 变量1

    什么是变量 在Java程序中,变量是基本的存储单元.是在程序运行中值可以改变的一块内存区域.变量是通过标识符(变量名).变量类型及可选的初始化器来定义的,此外,所有的变量都有作用域,作用域定义了变量的 ...

  10. iOS - 验证输入的是否是正确的身份证号码和手机号码

    - (BOOL)checkIdentityCardNo:(NSString*)cardNo { if (cardNo.length != 18) { return  NO; } NSArray* co ...