一.我们可以通过配置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. !! 机器学习常用工具
  2. isis协议_ISIS基础知识介绍
  3. 华为端到端项目管理流程_【达睿原创】供应链端到端管理 – 看华为是怎么做的...
  4. 人工玻璃体-技术指标汇总(持续更新中)
  5. ChipKill内存技术
  6. kvm虚拟机网络设置隔离模式(一键shell脚本)
  7. Android实现拍照并上传
  8. 声音就是你的武器!这样的攻防大赛你一定没有见过!
  9. 贪吃蛇c语言代码vc,纯C语言实现贪吃蛇游戏(VC6.0)
  10. 微信小程序二手交易系统ssm框架
  11. php iconv translit,php iconv translit for removing accents: not working as excepted?
  12. Macbook pro 2015款 换完硬盘bootcamp 尝试访问启动磁盘设置时出错解决方法
  13. Swift游戏实战-跑酷熊猫 04 熊猫的跳和滚的动作
  14. 爱奇艺网络流量分析引擎 QNSM 及其应用
  15. 战舰帝国服务器维护,【图片】9月17日更新公告亲爱的司令官:《战舰帝国》于9月17日维护,成功更新后可以获得200个钻石的更新补偿_战舰帝国吧_百度贴吧...
  16. 英语说10点20有计算机课,博雅课选课指南(1)
  17. ASP的2种开发模式
  18. 视频号灰度测试购物车功能,微信要扛起腾讯电商大旗了?
  19. bios显存改8g rx_自行更换显卡讯景RX570 4G黑狼版换BIOS切换键 (估计厂家用户认为折腾BIOS)...
  20. ubunt linux解压gz,ubuntu解压命令

热门文章

  1. 安装vue3.0脚手架
  2. nginx php配置重写,nginx 配置 php url 重写
  3. 关于数学计算机手抄报简单的,数学手抄报简单又漂亮
  4. day43-HTML、CSSHTML5/CSS3基础
  5. css3制作扇形菜单
  6. 云数据中心网络架构 -- 数据中心网络(DCN)架构(持续更新)
  7. 用下标的方式遍历对象
  8. 小米4x性能服务器图片介绍,红米4x怎么样 红米4X性能参数评测【详解】
  9. 2021年全国平均工资出炉,你达标了吗?
  10. 分享Python开发的13个小游戏(附源码)