一.我们可以通过配置Shared Pool(保证用户在内存中查找到已经缓存的语句)改进性能;还有一个重要的方法就是:使用户可以在内存找到他们所请求的数据! 这就需要通过Database Buffer Cache(数据库缓冲区的高速缓存区)来实现。

Buffer Cache是SGA的一个组件,用来缓存用户最近在数据库中访问过的段数据块的副本。这些副本和它们在磁盘上的对应块是同步的! 如果不同步,就是所谓的脏缓冲区! 从Cache往磁盘上写,我们称之为写盘。管理脏缓冲区的机制叫做Dirty List(脏列表)或Write List(写列表)。这个列表里面跟踪已经insert,update,delete但是还没有写盘的语句。最终的写盘工作由ORACLE后台进程Database Writer(DBW0)完成。

Buffer Cache也是由一LRU算法来管理。*FTS(全表扫描期间)表缓冲区直接放在LRU的最近最少使用那端。

二.测量Database Buffer Cache的性能

select 1 - ((physical.value - direct.value - lobs.value) / logical.value)

"Buffer Cache Hit Ratio"

from v$sysstat physical,v$sysstat direct,v$sysstat lobs,v$sysstat logical

where physical.name = 'physical reads'

and direct.name='physical reads direct'

and lobs.name='physical reads direct (lob)'

and logical.name='session logical reads';

上述语句当>90%实说明调整充分的。命中率是高的!

三.改进Database Buffer Cache的性能

1.最简单的方法就是加大它的大小。占SGA的45%比较合适!几个参数

(1).DB_BLOCK_SIZE 主数据库块大小默认是8K 在建立完数据库之后就不能改变

(2).DB_CACHE_SIZE (默认缓冲区池) 默认48M我们主要修改这个参数提高性能

alter system set db_cache_advice=on;使用oracle推荐的统计顾问,在正常操作数据库半小时之后

select name,size_for_estimate,v$db_cache_advice.ESTD_PHYSICAL_READS from v$db_cache_advice where block_size='8192' and advice_status='ON';

得到推荐的大小

select obj.owner,obj.object_name,obj.object_type,count(distinct bh.BLOCK#) "NUM. Buffers"

from dba_objects obj,v$bh bh

where obj.object_id=bh.OBJD

and owner != 'SYS'

group by obj.owner,obj.object_name,obj.object_type;

上述这段语句可以查看哪些对象正缓存再Buffer Cache中,正使用了多少个Buffer Cache缓冲区。

(3).使用多个缓冲池

alter system set db_cache_size=300M;

alter system set db_keep_cache_size=150M; 保持区

alter system set db_recycle_cache_size=50M; 回收区

将表分配给保持区

alter table col_cust storage (buffer_pool keep);

使用语句

select owner,segment_type,segment_name,buffer_pool

from dba_segments

where buffer_pool != 'DEFAULT';

可以查看分配情况

select name,block_size,current_size

from v$buffer_pool;

可以查看每个Buffer Pool的大小

select name "Buffer Pool",1 - (physical_reads / (db_block_gets + consistent_gets)) "Buffer Pool Hit Ratio"

from v$buffer_pool_statistics order by name;

可以查看每个Buffer Pool的命中率 KEEP越大越好,Recycle越小越好

(4).在内存中缓存表

虽然表可以放在保持区,但是由于Keep Pool也是由LRU控制的,所以当FTS(全表扫描)时,该表还是被放在LRU的最近最少使用那端。这样就有可能被移出。所以我们可以使用

alter table col_cust cache;的方法把表变成一个高速缓存区表

select owner,table_name from dba_tables where ltrim(cache)='Y'

可以查看高速缓存区表的信息

oracle缓存表

oracle的db_buffer_pool由三部分组成:

buffer_pool_defualt

buffer_pool_keep

buffer_pool_recycle

如果要把表钉死在内存中,也就是把表钉在keep区。

相关的命令为:

alter table ..... storage(buffer_pool keep);

这句命令把表示表如果缓存的话是缓存在keep区。

可以通过语句:

select table_name from dba_tables where buffer_pool='KEEP';查询到改表是放在keep区中的。

但是不意味着表已经被缓存了。

下面的语句把表缓存:

alter table .... cache;

可以通过

select table_name from dba_ tables where rtrim(cache)='Y';

查询到该表已经被缓存了。

加入到keep区的表不是说不能被移出内存,不过是比较不容易移出内存。

也可以手工来移出内存,命令如下:

alter table ... nocache;

相关文章:

[@more@]

oracle 调整缓存大小,Oracle调整缓冲区高速缓存相关推荐

  1. oracle调整sga大小,Oracle调整SGA大小

    Oracle调整SGA大小 Oracle 11g 只要设置 memory 就可以了.不需要单独对 sga_max_size 进行设置, 设置memory_max_target.memory_targe ...

  2. Mac电脑用预览功能调整图像大小?Mac调整图片大小方法

    要说到修改一张图片的尺寸大小,很多人的第一反应通常是打开 Photoshop 或者 Pixelmator,其实使用苹果MAC电脑有更简单方便的方法来调整图片的大小尺寸,OS X 自带的快速预览功能就可 ...

  3. MATLAB图形调整边框大小subplot调整空白区域大小

    来源 处理实验数据,由于很多个小类别,全部用个subplot绘制出来,发现两边的空白太多,想把两边空白删除.直接上图处理签和处理后的结果, 实验结果被我用hold off 取消掉了,不影响此处说明. ...

  4. centos调整页面大小_CentOS调整字符界面字体大小的方法

    机器环境: CentOS 6.0 GRUB 0.97 字符界面,无桌面环境. 问题:如何调整CentOS字符界面字体的大小: 如果字体大小不能调整,也可以提出调整显示分辨率的方法来达到使文字看起来大点 ...

  5. oracle设置缓存大小设置多少,【数据库类※从V$DB_CACHE_ADVICE中设置数据缓冲大小※】...

    [数据库类※从V$DB_CACHE_ADVICE中设置数据缓冲大小※]     Oracle 9i引入了一个新的途径来预测数据缓冲cache中附加数据缓存的所带来的好处的多少.V$DB_CACHE_A ...

  6. oracle数据库缓存 c,Oracle 19c数据库体系结构-2

    一. System Global Area Oracle 19c SGA 系统全局区域 (SGA) 是包含数据和控制信息的内存区域 Oracle 数据库实例.所有服务端和后台进程共享 SGA .启动数 ...

  7. oracle 11g初始段大小,Oracle 11g配置调优,一般需要注意哪些方面呢?

    一 创建数据库必须遵循的原则 1.强制数据库中创建的每一个表空间必须是本地管理. extent management local定义本地表空间. 2.确保数据库为每个用户自动分配一个默认的永久表空间. ...

  8. oracle 查询表物理大小,oracle查看表实际物理空间使用大小

    一种是分配给一个表的物理空间数量,而不管空间是否被使用.可以这样查询获得字节数: select segment_name, bytes from user_segments where segment ...

  9. linux lvm 调整分区大小,linux调整lvm分区大小(/home分区过大,/root分区过小)

    安装centos6.3使用自动推荐分区,发现一个问题/home 分区过大,超过了1.1T. [root@localhost ~]# df -h 文件系统              容量  已用  可用 ...

最新文章

  1. 有程序员称:阿里拼多多什么的跟hw相比,性价比都不高.....元芳,你怎么看?...
  2. Hinton:人类就是机器,绝妙的机器
  3. org.activiti.bpmn.exceptions.XMLException: src-resolve: 无法将名称 'extension' 解析为 'element declaration'
  4. 原理解析_SpringBoot自动装配原理解析
  5. 【矩阵乘法】Quad Tiling(poj 3420)
  6. starter_您是否尝试过MicroProfile Starter?
  7. a8处理器相当于骁龙几_天玑820相当于骁龙什么处理器?天梯图秒懂联发科天玑820性能排名...
  8. Linux里面nginx显示Hello,Nginx得知——Hello World模
  9. inkscape生成g代码_UG NX车削加工编程实例,从创建车削加工到生成G代码,简简单单...
  10. 【面试】最容易被问到的N种排序算法!
  11. [Noip2007]Core树网的核
  12. HTML5 WebRTC API无需网络获取本地IP
  13. 用Python制作圣诞树
  14. JavaWeb——JSP开发模型
  15. python 爬取淘宝第二弹(淘宝数据爬取)
  16. excel 的lookup和sumifs函数使用
  17. cmake整理:在编译时拷贝文件之add_custom_comand 和 add_custom_target
  18. 微机原理与接口技术:接口概述 详细笔记
  19. Windows XP 源代码在线泄露
  20. LNA设计学习心得记录----MOS管的选取

热门文章

  1. 关于js中的eval函数
  2. 华为Watch Buds耳机会防水吗?防水等级是多少?
  3. OpenGL(十九)——Qt OpenGL波动纹理(旗子的飘动效果)
  4. 解决 win7里部分依赖Qt的程序显示不清晰的问题
  5. Android之禁止APP截图、录屏
  6. Flyway——配置和使用(入门)
  7. 卷积神经网络模型解读及数学原理 ——翻拍图片识别
  8. html页面如何跳转到asp,asp点击按钮跳转页面 ASP中按钮的点击触发网页跳转
  9. jQuery源码分析之$.inArray()函数
  10. Tubi 快讯|第一季度收入增速同比增长近 30%