探究SQL Server 数据页缓冲区的内存瓶颈
SQL Server会把经常使用到的数据缓存在内存里(就是数据页缓存),用以提高数据访问速度。因为磁盘访问速度远远低于内存,所以减少磁盘访问量同样是数据库优化的重要方面。
当数据页缓存区出现内存不足,则会出现查询慢,磁盘忙等等问题。
分析方法:主要是用到性能计数器。
查看如下性能计数器:
1. SQL SERVER:Buffer Manager-Lazy Writes/sec:内存不足则会频繁调用Lazy Writer把数数据写入磁盘,此值会经常不为0.
2. SQL SERVER:Buffer Manager-Page life expectancy:内存不足时,此计数器表现为下降趋势或者一直停留在较低值。
3. SQL SERVER:Buffer Manager-Page reads/sec:内存不足时,则查询那些经常使用但又没有缓存在内存里的数据时,就不需要读取磁盘,这此值表现为持续上升或者停留在较高值。
4. SQL SERVER:Buffer Manager-Stolen pages:Stolen pages通常用于缓存执行计划,以备重用。内存不足时,SQL Server本身机制会优先清除执行计划缓存,则此值表现为下降或者较低水平。
查询当前用户任务等待:
复制代码 代码如下:
select * from rocesses
如果内存不足则,会看到较多的ASYNC_IO_COMPLETION等待类型。这是因为内存不足时:a.内存和磁盘间会频繁进行交互,磁盘负载增加 b.需要读取磁盘上的数据完成查询,磁盘负载增加。
也就是说这时候磁盘也出现了性能瓶颈,但是这只是“表面”的,我们要结合多个性能指标来认清根本原因是“内存不足”。
确定压力来源及解决办法:
通过前的分析,确定了数据页缓存相关的内存瓶颈。就要分析为什么会这样及解决办法。主要分为如下5个方面:
1. 外部压力
如果OS层面或者其它应用服务需要更多的内存,windows会压缩Database Pages的内存量。这时内存压力来自外部。可以查看如下性能计数器确定是否是外部压力:
1. SQL Server:Memory Manager-Total Server Memory:此计数器值会下降。
2. Memory:Available Mbytes:此值会下降到较低水平。
3. 在没有使用AWE或者Lock page in memory前提下,查看Process:Private Bytes-SqlServer和Process:Working Set-SqlServer,两者值会有显著下降。
解决方法:如果非DB专用服务器,则要权衡各个应用服务之间重要性来分配内存或者加大内存。尽量让服务器只运行SQL Server,成为DB专用服务器。
2. SQL Server自身对Database Page的使用压力
当Total Server Memory已经达到设定的Max Server Memory或者无法从OS获得更多内存,但是经常访问的数据量又远大于物理内存用于数据缓存的容量时,SQL Server被迫将内存的数据移入又移出,用于完成当前查询。
观察如下性能计数器:
1. SQL Server:Memory Manager-Total Server Memory 和 SQL Server:Memory Manager-Target Server Memory两者值将会相等。但是前者不会大于后者。
2. 将会出现“分析方法”所述之情况。
解决方法:既然SQL Server没有足够内存存放Database Page,那就要么增加SQL Server使用的内存量或者减少其使用的内存里。
增加:可以通增加物理内存,启用AWE等方法。
减少:可以通过横向扩展,有两台或者多台服务器分别载部分库;优化相关读取量较大的语句等。
3. Buffer Pool中的Stolen Memory压力
正常情况下Buffer Pool中的Stolen Memory不会给Database Pages造成压力。因为Database Pages有压力,会触发Lazy Writes,同时SQL Server 会清理Stolen Memory中的执行计划缓存。
但是,如果用户申明了过多的对象,而没有登出,并且占用内存过多,就会压缩Database Pages.如:游标,自定义引用的执行计划等。
解决方法:通常是会表现为a)用户提交的请求因内存不足无法完成,701错误;b)需要压缩某些clerk的'内存量,来完成用户请求,造成响应延时和缓慢。
通过查询_os_memory_clerks的字段Single_pages_kb,找出是哪个clerk使用了过多内存并分析其原因,然后解决之。
4. Multi-Page的压力
multi-page跟Buffer Pool共享OS的虚拟地址空间,如果multi-page使用过多内存,就会压缩Datbase pages。multi-page内存用量一般较小且相对固定,可能发生的情况有:
a. 未开启AWE的32位SQL Server只有2G地址空间,且用-g启动参数扩展的MemToLeave的上限。
b. 64位SQL Server调了内存泄露的第三方代码。
c. 使用带有大量参数或者较长的”IN”语句
d. 调高了Network Packet Size,大于或等于8KB,并且较多这种连接。
e. 大量复杂XML查询,或者第三代码。
解决方法: 通过查询_os_memory_clerks的字段multi_pages_kb,找出是哪个clerk使用了过多内存并分析其原因,然后解决之。
相關文章
-
SQLServer导出sql文件/表架构和数据操作方法
很多朋友问到sql server数据库”生成脚本”,只导出了数据库的sql脚本,而表里的数据依然没有导出来。很简单,看教程:注:我这里用的SQLServer2008,其它版本应该差不多。一、选中要导出的`数据库–>任务–>生成脚本(或者在任务 -
三级数据库:在SQLSERVER中实现RSA加密算法
为了使广大考生在备战计算机等级考试时,更快的掌握相应知识点,下面是小编搜索整理的三级数据库:在SQLSERVER中实现RSA加密算法,供参考练习,预祝考生们考出自己理想的成绩!/*本次修改增加了unicode的支持,但是加密后依然显示 -
Sql Server、Access数据排名的实现方法
但是,在SQL SERVER 2005 之前,SQL SERVER 2000 并没有提供这个直接的.函数供我们使用,同样 ACCESS 也是如此。下面我们分2种情况,来写出数据排名的实现过程。测试数据如下:Access复制代码 代码如下:select name, score, (s -
如何将Session值储存于SQL Server中呢
在平时的学习、工作或生活中,大家对作文都不陌生吧,作文是通过文字来表达一个主题意义的记叙方法。你知道作文怎样写才规范吗?以下是小编收集整理的写礼物的作文,仅供参考,希望能够帮助到大家。写礼物的作文1啊!这虽然并不 -
如何用JSP连接SQLServer数据库
Java基础用JSP连接SQLServer数据库,是我们在日常中经常用到的'。下面YJBYS小编为大家整理了具体的用法,希望对你有所帮助。,,复制到tomcat目录\common\lib\环境设置:jdbc驱动程序,,复制到tomcat目录\common\lib\2.设 -
SQL Server常用数据类型
数据类型是数据的一种属性,是数据所表示信息的类型。下面是YJBYS小编为大家搜索整理了关于SQL Server常用数据类型,欢迎参考阅读,希望对大家有所帮助。想了解更多相关信息请持续关注我们应届毕业生培训网!SQL Server 200 -
MS SQL Server Management Studio Express安装图文具体步骤
Microsoft sql server Management Studio Express (SSMSE) 是一种免费、易用的图形管理工具,用于管理 SQL Server 2005 Express Edition 和具有高级服务的 SQL Server 2005 Express Edition。SSMSE 还可以管理任何版本 -
SQLserver找出执行慢的SQL语句
复制代码 代码如下:////// 批量执行SQL语句//////SQL语句数组///SQL参数对象数组///public static Int32 ExecuteSqls(String[] Sqlstr, Listparam){String ConnStr = GetSqlConnection();using (SqlConnection conn -
SQL server中字符串逗号分隔函数
继SQl -Function创建函数数据库输出的结果用逗号隔开,在开发中也有许多以参数的'形式传入带逗号字条串参数(数据大时不建议这样做)例:查找姓名为“张三,李二” 的数据此时在数据库里就要对此参数做处理如图:函数代码如下C -
J2EE SQL Server中文乱码问题解读方法
J2EE 带动了Java在企业级的发展,但随着一些轻量级组件的出现,J2EE的臃肿和开发难度高的缺点越来越引起了许多人的注意,EJB2.0也被许多人称为累赘。下面是小编整理的关于J2EE SQL Server中文乱码问题解读方法,欢迎大家参考