浅谈Oracle Buffer Cache的优化思路

Buffer Cache

成都做网站、成都网站制作的开发,更需要了解用户,从用户角度来建设网站,获得较好的用户体验。成都创新互联公司多年互联网经验,见的多,沟通容易、能帮助客户提出的运营建议。作为成都一家网络公司,打造的就是网站建设产品直销的概念。选择成都创新互联公司,不只是建站,我们把建站作为产品,不断的更新、完善,让每位来访用户感受到浩方产品的价值服务。

The database buffer cache is the portion of the SGA that holds copies of data blocks read from datafiles. All user processes concurrently connected to the instance share access to the database buffer cache是sga的一部分,用于保持从数据文件读取数据块的副本。所有用户进程共同访问database buffer cache。

数据库的读写操作应尽量在内存中完成,减少IO次数是数据库性能优化的基本策略。

优化buffer cache的思路:

1)根据经验设置db_cache_size参数,例如,db_cache_size=SGA_TARGET*80%。

2)分析AWR报告中的Buffer Hit值(Instance Efficiency Percentages (Target 100%) )。

需要关注的等待事件(如果这些等待事件出现在Top-5中,则说明Buffer Cache工作效率不高):

 
 
 
 
  1. Latch:cache buffer chains  
  2.  
  3. Latch:cache buffer LRU chains  
  4.  
  5. Buffer busy waits  
  6.  
  7. Read waits  
  8.  
  9. Free buffer waits  
  10.  
  11. Latch:cache buffer chains与Latch:cache buffer LRU chains 

表示数据库中存在一些数据块被频繁读取,即所谓的热块数据。如,频繁读取的代码表(?),UNDO头数据(?)、单调增长的索引等。

以下可以查询热块数据:

 
 
 
 
  1. select * from (select owner,object_name,object_type,statistic_name,sum(value)  
  2.  
  3. from v$segment_statistics  
  4.  
  5. group by owner,object_name,object_type,statistic_name  
  6.  
  7. order by sum(value) desc)  
  8.  
  9. where rownum<10; 

优化方法:如,减少代码数据的读取次数,使用reverse key索引,以及10g的Global Hash-patition分区索引等。

Buffer busy waits

表示多个应用在并发访问某个Buffer Cache数据块时出现等待事件。这种数据块可能是应用表或索引,也可能是UNDO(?)、Segment Header(?)等系统数据。

以下可以查询等待事件涉及的对象:

 
 
 
 
  1. select object_name,statistic_name,value   
  2.  
  3. from v$segment_statistics   
  4.  
  5. where statistic_name ='buffer busy waits' and value > 2000; 

优化方法:如,分析是否有全表扫描,索引是否太多,索引单调增长等,归根到底还是分析应用。

Read waits

包括:db file sequential read、db file parallel read、db file scattered read。一般而言,只要db file scattered read不是最主要的等待事件,或者所占比例不高,上述事件即使出现在Top-5等待事件中也是正常现象。

如果这些等待事件非常高,或者所占比例很高。优化方法:1,同样地,首先优化应用,如是否有太多的全表扫描,索引碎片是否严重。2.适当扩大db_cache_size。3.分析磁盘I/O效率。

Free buffer waits

表示将Buffer Cache 内容写到磁盘的速度,赶不上其它应用申请空闲Buffer Cache的要求。优化方法:同样地,首先优化应用,如是否有太多的全表扫描,索引效率是否比较高。2.适当扩大db_cache_size。3.扩大db_writer_processes参数,增加DBWn进程数量,加快将Buffer Cache内容写到磁盘的速度。

db_writer_processes默认为1或cpu_count/8,默认值通常就可以,如果需要设置db_writer_processes,请不要超过cpu_count,以避免cpu资源无谓消耗。

其它优化方法,将表设计成cache表,等等。

对于优化,总的来说还是优化应用。本文就介绍到这里,谢谢!

【编辑推荐】

  1. MSSQL数据库跨表和跨数据库查询方法简介
  2. SQL Server 2005数据库用户权限管理的设置
  3. Oracle跟踪文件分析工具TKPROF使用简介
  4. 利用mysql的audit审计功能记录用户操作信息
  5. T-SQL行列相互转换命令:PIVOT和UNPIVOT使用详解

当前题目:浅谈Oracle Buffer Cache的优化思路
当前地址:http://www.shufengxianlan.com/qtweb/news42/254592.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联