oracle 调整缓存大小,Oracle调整缓冲区高速缓存
一.我们可以通过配置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调整缓冲区高速缓存相关推荐
- oracle调整sga大小,Oracle调整SGA大小
Oracle调整SGA大小 Oracle 11g 只要设置 memory 就可以了.不需要单独对 sga_max_size 进行设置, 设置memory_max_target.memory_targe ...
- Mac电脑用预览功能调整图像大小?Mac调整图片大小方法
要说到修改一张图片的尺寸大小,很多人的第一反应通常是打开 Photoshop 或者 Pixelmator,其实使用苹果MAC电脑有更简单方便的方法来调整图片的大小尺寸,OS X 自带的快速预览功能就可 ...
- MATLAB图形调整边框大小subplot调整空白区域大小
来源 处理实验数据,由于很多个小类别,全部用个subplot绘制出来,发现两边的空白太多,想把两边空白删除.直接上图处理签和处理后的结果, 实验结果被我用hold off 取消掉了,不影响此处说明. ...
- centos调整页面大小_CentOS调整字符界面字体大小的方法
机器环境: CentOS 6.0 GRUB 0.97 字符界面,无桌面环境. 问题:如何调整CentOS字符界面字体的大小: 如果字体大小不能调整,也可以提出调整显示分辨率的方法来达到使文字看起来大点 ...
- oracle设置缓存大小设置多少,【数据库类※从V$DB_CACHE_ADVICE中设置数据缓冲大小※】...
[数据库类※从V$DB_CACHE_ADVICE中设置数据缓冲大小※] Oracle 9i引入了一个新的途径来预测数据缓冲cache中附加数据缓存的所带来的好处的多少.V$DB_CACHE_A ...
- oracle数据库缓存 c,Oracle 19c数据库体系结构-2
一. System Global Area Oracle 19c SGA 系统全局区域 (SGA) 是包含数据和控制信息的内存区域 Oracle 数据库实例.所有服务端和后台进程共享 SGA .启动数 ...
- oracle 11g初始段大小,Oracle 11g配置调优,一般需要注意哪些方面呢?
一 创建数据库必须遵循的原则 1.强制数据库中创建的每一个表空间必须是本地管理. extent management local定义本地表空间. 2.确保数据库为每个用户自动分配一个默认的永久表空间. ...
- oracle 查询表物理大小,oracle查看表实际物理空间使用大小
一种是分配给一个表的物理空间数量,而不管空间是否被使用.可以这样查询获得字节数: select segment_name, bytes from user_segments where segment ...
- linux lvm 调整分区大小,linux调整lvm分区大小(/home分区过大,/root分区过小)
安装centos6.3使用自动推荐分区,发现一个问题/home 分区过大,超过了1.1T. [root@localhost ~]# df -h 文件系统 容量 已用 可用 ...
最新文章
- !! 机器学习常用工具
- isis协议_ISIS基础知识介绍
- 华为端到端项目管理流程_【达睿原创】供应链端到端管理 – 看华为是怎么做的...
- 人工玻璃体-技术指标汇总(持续更新中)
- ChipKill内存技术
- kvm虚拟机网络设置隔离模式(一键shell脚本)
- Android实现拍照并上传
- 声音就是你的武器!这样的攻防大赛你一定没有见过!
- 贪吃蛇c语言代码vc,纯C语言实现贪吃蛇游戏(VC6.0)
- 微信小程序二手交易系统ssm框架
- php iconv translit,php iconv translit for removing accents: not working as excepted?
- Macbook pro 2015款 换完硬盘bootcamp 尝试访问启动磁盘设置时出错解决方法
- Swift游戏实战-跑酷熊猫 04 熊猫的跳和滚的动作
- 爱奇艺网络流量分析引擎 QNSM 及其应用
- 战舰帝国服务器维护,【图片】9月17日更新公告亲爱的司令官:《战舰帝国》于9月17日维护,成功更新后可以获得200个钻石的更新补偿_战舰帝国吧_百度贴吧...
- 英语说10点20有计算机课,博雅课选课指南(1)
- ASP的2种开发模式
- 视频号灰度测试购物车功能,微信要扛起腾讯电商大旗了?
- bios显存改8g rx_自行更换显卡讯景RX570 4G黑狼版换BIOS切换键 (估计厂家用户认为折腾BIOS)...
- ubunt linux解压gz,ubuntu解压命令