oracle性能优化之rollbacksegment优化

上传人:xiao****1972 文档编号:84085154 上传时间:2019-03-02 格式:DOC 页数:2 大小:27KB
返回 下载 相关 举报
oracle性能优化之rollbacksegment优化_第1页
第1页 / 共2页
oracle性能优化之rollbacksegment优化_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《oracle性能优化之rollbacksegment优化》由会员分享,可在线阅读,更多相关《oracle性能优化之rollbacksegment优化(2页珍藏版)》请在金锄头文库上搜索。

1、1、概念Transaction以轮循的方式使用rollback segment里的extent,当前所在的extent满时就移动到下一个extent。可能有多个transaction同时向同一个extent写数据,但一个rollback segment block中只能保存一个transaction的数据。Oracle 在每个Rollback segment header中保存了一个transaction table,包括了每个rollback segment中包含的事务信息,rollback segment header的活动控制了向rollbak segment写入被修改的数据。rollb

2、ack segment header是经常被修改的数据库块,因此它应该被长时间留在buffer cache中,为了避免在transaction table产生竞争导致性能下降,应有多个rollback segment或应尽量使用oracle server 自动管理的rollback segment。2、诊断rollback segment header的竞争如果rollback segment 由手工管理,下列措施诊断rollback segment header的竞争SELECT class,count FROM v$waitstat WHERE class LIKE %undo% ;SEL

3、ECT Sum(Value) sum FROM v$sysstat WHERE NAME IN (db block gets,consistent gets);任何类型的等待次数(count)与总请求数(sum)的比率,不能超过1%。或select sum(waits)*100/sum(gets) Ratio, sum(waits) Waits, sum(gets) Gets from v$rollstat;waits的汇总数与gets的汇总数的比率应低于1%,如果超过1%,应创建更多的rollback segment。下列字段数值如果大于0,则表明在rollback segment head

4、er上存在竞争:A、v$rollstat 中的waitsB、v$waitstat中的undo header行C、v$system_event中的undo segment tx slot事件3、消耗更少的rollback segment1)如果是删除表里所有的数据,尽可能使用trauncate而不是delete。2)在应用中允许用户有规律的提交,尽可能不用长事务。3) Import Set COMMIT = Y Size the set of rows with BUFFER Export: Set CONSISTENT=N SQL*Loader: Set the COMMIT interval

5、s with ROWS4、小回滚段可能出现的问题A、事务由于缺少回滚空间失败B、由于下列原因导致的“Snapshot too old”问题:Block里的事务列表被刷新,block里的SCN比列表Interested Transaction List(ITL)里起始事务的SCN更新;Rollback segment header里的Transaction slot被重用;回滚数据已经被重写;5、9i的自动回滚管理Undo_managment指定了回滚空间的管理方式:Auto:自动管理;Manual:手工管理回滚段。Undo_retention指定了回滚数据的保留期限;Undo_tablespa

6、ce指定了被使用的回滚表空间;Oracle自动管理的表空间可以在常见数据库的时候创建,也可以单独建立。回滚表空间可以相互转换(switch),但在某一时刻只能有一个回滚表空间处于活动状态。回滚表空间处于非活动状态时可以删除,如果有对处于被删除回滚表空间里的已提交事务的查询时,oracle会返回一个错误。估计undo tablespace大小的公式:Undo space = (undo_retention * (undo blocks per second * db_block_size) + db_block_size;可以使用下列的sql设定undo_retention和undo table

7、space:select (rd*(ups*overhead)+overhead) bytes from (select value rd from v$parameter where name =undo_retention),(select (sum(undoblks)/sum(end_time-begin_time)*10800) ups from v$undostat),(select value overhead from v$parameter where name=db_block_size);其中:Rd:undo_retention设置的时间;Ups:undo blocks per second;Overhead:rollback segment header;来源:网络 编辑:联动北方技术论坛

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号