位置: 编程技术 - 正文

SQL Server性能调优之缓存(sqlserver数据库性能情况)

编辑:rootadmin

推荐整理分享SQL Server性能调优之缓存(sqlserver数据库性能情况),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sqlserver2019性能,sqlserver2019性能,sqlserver2019性能,sqlserver提高性能,sqlserver提高性能,sqlserver性能调优,sqlserver性能调优实战评分,SQL Server性能调优实战,内容如对您有帮助,希望把文章链接给更多的朋友!

在执行任何查询时,SQL Server都会将数据读取到内存,数据使用之后,不会立即释放,而是会缓存在内存Buffer中,当再次执行相同的查询时,如果所需数据全部缓存在内存中,那么SQL Server不会产生Disk IO操作,立即返回查询结果,这是SQL Server的性能优化机制。

一,主要的内存消费者(Memory Consumer)

1,数据缓存(Data Cache)

Data Cache是存储数据页(Data Page)的缓冲区,当SQL Server需要读取数据文件(File)中的数据页(Data Page)时,SQL Server会把整个Page都调入内存(内存中的一个Page叫做buffer),Page是数据访问的最小单元。

当用户修改了某个Page上的数据时,SQL Server 会先在内存中修改Buffer,但是不会立即将这个数据叶写回硬盘,而是等到CheckPoint或lazy Writer进程运行时集中处理。当用户读取某个Page后,如果SQL Server没有内存压力,它不会在内存中删除这个Page,因为内存中的数据页始终存放着数据的最新状态,如果有其他用户使用这个Page,SQL Server 不需要从硬盘中读取一次,节省语句执行的时间。理想情况是SQL Server将用户需要访问的所有数据都缓存在内存中,SQL Server 永远不需要去硬盘读取数据,只需要在CheckPoint 或 lazy Write运行时把修改过的页面写回硬盘即可

2,查询计划缓存(Query Plan Cache)

存储查询语句和存储过程的执行计划,以供重用,而不需要重新编译(Compile),因为编译查询语句产生执行计划是一个非常耗费资源的过程。

二,查看内存消耗

在SQL Server中,只有内存书记员(Memory Clerk)能够分配内存,Memory Clerk会记录已经分配内存的数量,任何一个需要使用内存的对象,必须创建自己的Memory Clerk,并使用该Memory clerk来分配内存。

1,查看Memory clerk分配的内存量

对于内存结点,只在DAC中使用。

2,统计Memory Clerk分配的内存总量

消耗内存较大的Clerk是:

MEMORYCLERK_SQLBUFFERPOOL:基本是Buffer Pool中page的大小 OBJECTSTORE_LOCK_MANAGER:锁结构使用的内存,当发生严重的锁阻塞时,这表明系统中,存储大量锁,造成锁管理占用大量的内存; CACHESTORE_OBJCP:触发器和存储过程等模块(Module)的执行计划占用的缓存空间; CACHESTORE_SQLCP:动态TSQL语句,即席(Adhoc)查询和预编译(Prepared) TSQL的执行计划缓存; CACHESTORE_COLUMNSTOREOBJECTPOOL:列存储索引(ColumnStore Index)占用的缓存

3,查看缓存中的数据页

当数据页从硬盘读取到内存之后,该数据页被复制到缓冲池(Buffer Pool),供SQL Server重用。每个缓存的数据页都有一个缓存描述器(Buffer Descriptor),用户唯一标识内存中的数据页,在SQL Server实例中缓存的每一个数据页,都能从 sys.dm_os_buffer_descriptors 查看缓存描述的信息。

4,查看计划缓存

产生执行计划是十分消耗CPU资源的,SQL Server会在内存的Plan Cache中存储每个查询计划(Query Plan),及其占用的内存空间,重用次数等信息。

三,清空缓存

在调优存储过程性能时,清空缓存是必需的,缓冲池(Buffer Pool)是SQL Server的缓存管理器,包含了SQL Server的绝大部分缓存数据(Cache),例如,执行计划缓存(Plan cache),数据缓存(Data cache)等。

清空缓存常用的命令有如下三个:

Checkpoint和DBCC DROPCLEANBUFFERS 用于清理数据缓存(Data Cache)中的脏页(dirty pages)和干净页(clean pages),而DBCC FREEPROCCACHE 用于清空所有的计划缓存(Plan Cache)。

SQL Server性能调优之缓存(sqlserver数据库性能情况)

1,清空数据缓存

checkpoint 用于将脏页(Dirty Pages)写入硬盘,脏页(Dirty Pages)是指数据页读入缓存后,被修改过,导致内存中数据页和硬盘中的数据页中的内容不同;干净页(Clean Pages)是指数据页被读入缓存后,没有被修改过,所以,内存中的数据页和硬盘中的数据页中的内容相同。不管是Dirty pages 还是 Clean pages 都是Data Cache,在性能调优时,都必须从内存中清理掉,否则,查询性能将忽略掉数据从硬盘加载到内存的IO消耗,影响查询语句的执行情况。

CHECKPOINT 命令用于产生冷缓存(Cold buffer Cache),该命令将当前数据库产生的所有脏页写入到硬盘,并清理内存buffer;在执行CHECKPOINT命令之后,执行 DBCC DROPCLEANBUFFERS 用于从缓冲池中清空所有的干净页。

在性能测试时,使用DBCC DROPCLEANBUFFERS从SQLSERVER的数据缓存池中清除所有的clean缓存数据,需要注意的是该命令只移走干净的缓存,不移走脏缓存。因此,在执行这个命令前,应该先执行CheckPoint,将所有脏页写入磁盘,这样在运行DBCC RROPCLEANBUFFERS 时,可以保证所有的数据缓存被清理,而不是其中的一部分。

2,清空计划缓存

计划缓存(Plan Cache)用于缓存查询语句的执行计划,每一条查询语句在执行之后,其查询计划都会缓存Plan Cache中。在产品环境中,不要轻易清理掉Plan Cache。如果检测到某个Plan Cache产生参数嗅探问题,导致性能十分低下,推荐修改查询语句,重新编译存储过程,以单独刷新该SP的计划缓存。

DBCC FREEPROCCACHE [ ( { plan_handle | sql_handle} ) ]

计划缓存,之前叫做过程缓存(procedure cache),执行DBCC FREEPROCCACHE 命令,释放所有的计划缓存,这回导致存储过程,AdHoc 查询等查询必须重新编译,产生新的计划缓存。

四,强制重新编译执行计划

修改存储过程,触发器等模块(Module)能够使其执行计划重新编译,除此之外,还有其他方法,能够强制重新编译执行计划

1,标记,下次重新编译

使用该存储过程,标记一个执行模块(SP,Trigger,User-Defined Function)在下次执行时,重新编译执行计划

sys.sp_recompile [ @objname = ] 'object'

2,不复用执行计划

在创建存储过程时,使用WITH RECOMPILE 选项,在每次执行SP时,都重新编译,使用新的执行计划。

3,执行时重新编译

在执行存储过程时,重新编译存储过程的执行计划

4,语句级别的重新编译

在SP中,使用查询选项 option(recompile),只重新编译该语句级别的执行计划

SQL Server在执行查询之后,查询提示(RECOMPILE)指示存储引擎将计划缓存抛弃,在下次执行存储过程时,强制查询优化器重新编译,生成新的执行计划。在重新编译时,SQL Server 优化器使用当前的变量值生成新的计划缓存。

附:

冷缓存,热缓存,脏缓存和干净缓存名词解释:

净缓存页(Clean Buffer) 是指内存中未被修改的数据页,DBCC DROPCLEANBUFFERS 用于从缓冲池(Buffer Pool)移除干净页,释放Buffer。 脏缓存页(Dirty Buffer)是指数据页在内存中被修改,但是还没有写入到硬盘中,导致硬盘中的数据不同于内存,通常情况下,脏页通过CHECKPOINT进程来自动同步,CHECKPOINT 将脏页数据写入到硬盘中,使内存和硬盘文件中的数据保持一致,能够减少数据还原的时间。 冷缓存页(Cold Buffer)是指,在数据处理阶段,最近没有被使用的缓存页。 热缓存页(Hot Buffer)是指,在数据处理阶段,最近经常被使用的缓存页。

参考文档:

Recompile a Stored Procedure

What is a COLD, DIRTY or CLEAN Buffer

标签: sqlserver数据库性能情况

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

上一篇:SQLServer存储过程实现单条件分页(sqlserver存储过程加密)

下一篇:SQL Server中使用sp_password重置SA密码实例(SQL Server中使用的SQL是)

  • 委托加工物资增值税纳税义务发生时间
  • 进料加工要交税吗
  • 税友的财务软件叫什么
  • 去税务局开增值税专用发票需要缴费吗
  • 实收资本库存现金凭证怎么开
  • 附加税减免所得税汇缴的时候需要调整吗
  • 工商年报填好后怎样公示
  • 外地建筑工程开票流程
  • 增值税即征即退收入要交企业所得税吗
  • 委托外单位加工发出的材料分录
  • 建筑安装专票票样
  • 公司收到银行转账会计分录
  • 员工垫付公司费用法规
  • 收到赞助费如何做分录
  • 财产租赁所得如何申报
  • 销售肉制品税率
  • 单位杂工费报销计什么科目
  • 补偿金满一年不满一年半
  • 19年新会计制度
  • 采购均价怎么计算
  • 土地闲置费能否扣除
  • 金融企业贷款利息收入确认
  • 电子税务局印花税税种认定
  • 出口信用证议付支出是什么
  • 出口退免税资格备案
  • 当收到转账支票时,应该如何处理?
  • windows10软件图标不正常显示
  • mac host is down
  • 资本成本的组成
  • 劳务分包费用组成比例
  • 弃置费用预计负债的会计处理
  • php utf8转gb2312
  • 土豆发芽了能吃吗有没有毒
  • 补提坏账准备为什么不调整应纳税
  • visual studio code 调试php方法(图文详解)
  • 代扣代缴个人所得税手续费返还 增值税
  • nacos安装包
  • 生态位模型原理
  • linux 常用命令大全及其详解
  • cuppath
  • 贸易公司结转销售成本凭证怎么做
  • 员工安全培训费可以计入安全费用吗
  • 管家婆实收资本显示负数什么原因
  • 在售楼部帮客户卖房犯法吗
  • java获取resources下文件路径
  • mongodb怎么用
  • 企业收利息会计科目
  • 非货币性资产交换的记忆口诀
  • 航空电子客票行程单是发票吗
  • 超市的小票能入账吗
  • 存货核算方法有五种
  • 营业税金及附加是什么科目
  • 实收资本什么时候交齐
  • 现金短缺与溢余解析
  • 三证合一办理流程及费用
  • 虚增利润怎么调整
  • 转账支票转账需要带什么
  • 签发空头支票的罚款
  • sql中存储过程的用法
  • win9系统
  • ubuntu搜索已安装软件
  • win8怎么设置定时关机
  • Win7系统打开D盘文件后怎么没有后退箭头
  • Win10年度升级版将正式提供暗黑主题 未自定义颜色都会变暗
  • win7移动软件
  • ms-dos 6.2批处理文件高级指南
  • 列宽自适应
  • 如何用python进行数据处理
  • android sql语句
  • jquery自带的弹出框
  • 前后端调用
  • [置顶] 快来貌相则不达很好skmzx5
  • js中prototype的作用
  • 1万4千块钱交多少个人所得税
  • 怎么查其他公司的财务报表
  • 车船税每年多少钱
  • 香港企业查询系统
  • 申请电子发票需要盖章吗
  • 水费不用交吗
  • 公司忘记报税了怎么补
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设