位置: 编程技术 - 正文

SQL Server 数据页缓冲区的内存瓶颈分析(sqlserver界面)

编辑:rootadmin
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本身机制会优先清除执行计划缓存,则此值表现为下降或者较低水平。 查询当前用户任务等待: 如果内存不足则,会看到较多的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)用户提交的请求因内存不足无法完成,错误;b)需要压缩某些clerk的内存量,来完成用户请求,造成响应延时和缓慢。 通过查询sys.dm_os_memory_clerks的字段Single_pages_kb,找出是哪个clerk使用了过多内存并分析其原因,然后解决之。 4. Multi-Page的压力 multi-page跟Buffer Pool共享OS的虚拟地址空间,如果multi-page使用过多内存,就会压缩Datbase pages。multi-page内存用量一般较小且相对固定,可能发生的情况有: a. 未开启AWE的位SQL Server只有2G地址空间,且用-g启动参数扩展的MemToLeave的上限。 b. 位SQL Server调了内存泄露的第三方代码。 c. 使用带有大量参数或者较长的”IN”语句 d. 调高了Network Packet Size,大于或等于8KB,并且较多这种连接。 e. 大量复杂XML查询,或者第三代码。 解决方法: 通过查询sys.dm_os_memory_clerks的字段multi_pages_kb,找出是哪个clerk使用了过多内存并分析其原因,然后解决之。 作者:Joe.TJ

推荐整理分享SQL Server 数据页缓冲区的内存瓶颈分析(sqlserver界面),希望有所帮助,仅作参考,欢迎阅读内容。

SQL Server 数据页缓冲区的内存瓶颈分析(sqlserver界面)

文章相关热门搜索词:sql server 页的大小,sql server2019界面,sql数据库界面,sql server中一个数据页的大小,sqlserver中一个数据页的大小是多少kb,sql server页面,sqlserver数据页,sql server页面,内容如对您有帮助,希望把文章链接给更多的朋友!

sqlserver 查询数据库大小的方法 但Insus.NET想到的是,从下面的SQL语句,就可以查询到数据库大小。因此分享于此。SELECTDB_NAME(database_id)AS[DatabaseName],[Name]AS[LogicalName],[Physical_Name]AS[PhysicalN

SqlServer 索引自动优化工具 鉴于人手严重不足(当时算两个半人的资源),打消了逐个库手动去改的念头。当前的程序结构不允许搞革命的做法,只能搞搞改良,所以准备搞个自

优化 SQL Server 索引的小技巧 在本文中,我将说明如何用SQLServer的工具来优化数据库索引的使用,本文还涉及到有关索引的一般性知识。关于索引的常识影响到数据库性能的最大因

标签: sqlserver界面

本文链接地址:https://www.jiuchutong.com/biancheng/348175.html 转载请保留说明!

上一篇:SQL处理多级分类,查询结果呈树形结构(sql多级汇总)

下一篇:sqlserver 查询数据库大小的方法(sqlserver查询数据库数据量)

  • 附加税做账交多了如何冲回
  • 研发费用加计扣除是什么意思啊
  • 包装运杂费结转生产成本会计分录
  • 税务处理决定书与税务处罚决定书
  • 为什么收不到发票短信?
  • 工资 小数点
  • 结转损益管理费用在借方
  • 库存完工产品属于什么会计科目,什么类别
  • 出口旧设备最新政策
  • 会计利润包不包括营业外支出
  • 收到捐赠设备
  • 票据贴现的账务处理案例
  • 承兑 拆分
  • 零税率的发票
  • 出纳在银行领了钱出纳要怎样记帐?
  • 工程施工合同如何核算收入成本?
  • 固定资产更换配件怎么界定是否满足资本化
  • 差额纳税的会计处理
  • 季节工有工伤吗
  • 水利建设专项收入
  • 成本费用调整法
  • 一年内到期的应收质保金
  • 加速折旧法主要包括哪些内容
  • 母公司拨款给子公司的账务处理
  • 对子公司投资应采取的核算方法
  • 私募股权基金税收主要涉及的是什么税收问题
  • 计提工资社保公式是什么
  • 借支单如何做账科目
  • 公司餐饮费怎么做账
  • 主板清除bios
  • php类型判断
  • 进项税额转出会计分录福利费
  • php延迟2秒执行
  • 其他业务收入与营业外收入
  • LNMP部署laravel以及xhprof安装使用教程
  • php获取数组的值
  • 公司盈利怎么分配给股东
  • 企业出租房屋怎么做账
  • 金税三期税收管理系统响应异常返回信息:没有查询
  • vue2和vue3区别面试题
  • win10下 yolov8 tensorrt模型加速部署【实战】
  • 图像分类实战
  • 收取违约金能作为合同自动终止要件吗
  • 公司名义送花圈
  • python多线程编程案例
  • 企业出口证明
  • 影响公司股利分成的因素
  • 专用发票的用途
  • 去银行提取备用金不是会计本人需要给谁打电话
  • 以前年度社保计提出错了怎么调整
  • 预收款收入确认
  • 留底税额怎么形成的
  • 待抵扣进项税额和待认证进项税额的区别
  • 企业收到加盟费怎么开发票
  • 新公司初期费用全部入哪里
  • 暂估未取得发票汇缴纳税调增怎么填
  • 普票冲红需要收回原来的发票吗
  • 网络发票管理办法细则
  • 公司购买的车辆
  • 加盟店直营店什么意思
  • 电话费计入什么二级科目
  • Windows Server 2008故障转移群集简介
  • 快速任务栏
  • linux常见信号
  • 系统引导程序出错了如何修复
  • windows 7磁盘
  • csinject.exe是什么程序的进程 csinject进程是安全的吗
  • 苹果Mac系统怎么切换输入法
  • linux邮件设置方法
  • win10预览版21390
  • win8.1删除所有内容并重新安装
  • 批处理语言 从入门到精通
  • jquery validation
  • cocos lua调试
  • python开发软件教程
  • javascript 进阶篇1 正则表达式,cookie管理,userData
  • jquery从左到右渐渐显示
  • unity3d打包成apk
  • 河南省地方税务局公告2011年第10号
  • 朝阳地税局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设