简单谈谈Oracle10G中的闪回恢复区(2)

文章作者 100test 发表时间 2007:03:14 13:54:28
来源 100Test.Com百考试题网


闪回恢复区中添加或删除文件等变化都将记录在数据库的 alert 日志中,Oracle 10g 也针对该新特性提供了一个新的视图, DBA_OUTSTANDING_ALERTS,通过该视图可以得到相关的信息。

DBA_OUTSTANDING_ALERTS 视图的存在体现了 Oracle 愈加人性化的一面。我们先来看一下该视图的基本结构,后面会用到。





SQL> DESC dba_outstanding_alerts 

Name Null? Type 

-------------------------------------------------------------------------- 

SEQUENCE_ID NUMBER 

REASON_ID NOT NULL NUMBER 

OWNER VARCHAR2(30) 

OBJECT_NAME VARCHAR2(513) 

SUBOBJECT_NAME VARCHAR2(30) 

OBJECT_TYPE VARCHAR2(64) 

REASON VARCHAR2(4000) 

TIME_SUGGESTED TIMESTAMP(6) WITH TIME ZONE 



CREATION_TIME TIMESTAMP(6) WITH TIME ZONE 

SUGGESTED_ACTION VARCHAR2(4000) 

ADVISOR_NAME VARCHAR2(30) 

METRIC_VALUE NUMBER 

MESSAGE_TYPE VARCHAR2(12) 

MESSAGE_GROUP VARCHAR2(64) 

MESSAGE_LEVEL NUMBER 

HOSTING_CLIENT_ID VARCHAR2(64) 

MODULE_ID VARCHAR2(64) 

PROCESS_ID VARCHAR2(128) 

HOST_ID VARCHAR2(256) 

HOST_NW_ADDR VARCHAR2(256) 

INSTANCE_NAME VARCHAR2(16) 

INSTANCE_NUMBER NUMBER 

USER_ID VARCHAR2(30) 

EXECUTION_CONTEXT_ID VARCHAR2(60) 

ERROR_INSTANCE_ID VARCHAR2(142) 

SQL>

10g 的新视图 V$RECOVERY_FILE_DEST 包含闪回恢复区的相关信息:

SQL> desc V$RECOVERY_FILE_DEST 

Name Null? Type 

----------------------------------------------------------------------------- 

NAME VARCHAR2(513) 

SPACE_LIMIT NUMBER 

SPACE_USED NUMBER 

SPACE_RECLAIMABLE NUMBER 

NUMBER_OF_FILES NUMBER 

SQL> SELECT NAME, space_limit, space_used, space_reclaimable space_rec, 

2 number_of_files file_num 

3 FROM v$recovery_file_dest. 

NAME SPACE_LIMIT SPACE_USED SPACE_REC FILE_NUM 

---------------------------------------------------------------------------- 

/u01/app/oracle/flash_recovery_area 2147483648 1106849280 602410496 30 

SQL>

在一些 10g 的动态视图里(V$CONTROLFILE,V$LOGFILE,V$ARCHIVED_LOG,V$DATAFILE_COPY等)的新的列 IS_RECOVERY_DEST_FILE ,指明相关的文件是否在恢复区内。

SQL> SELECT recid, blocks, is_recovery_dest_file 

2 FROM v$archived_log 

3 WHERE recid < 5. 



RECID BLOCKS IS_RECOVERY_DEST_FILE 

---------- ---------- ---------------------------------------- 

1 20072 YES 

2 19566 YES 

3 19566 YES 

4 19566 YES 

SQL>

1.5. 闪回恢复区中文件的保持策略

·持久文件从不会被删除。

·通过RMAN 配置策略过期的文件会被删除。

·已经拷贝到磁带上的临时性文件会被删除。

·在 Data Guard 环境中,当已归档的重作日志文件可以从闪回恢复区中删除的时候,可以应用归档的重作日志删除策略进行自动删除(在恢复管理器中CONFIGURE ARCHIVELOG DELETION POLICY TO ......)。

在闪回恢复区中的空间使用超过 85% 的时候,数据库将会向 alert 文件中写入告警信息。而当超过97%的时候将会写入严重告警信息。当闪回恢复区空间不够的时候,Oracle将报告如下类似的错误:

ORA-19809: limit exceeded for recovery files 

ORA-19804: cannot reclaim 52428800 bytes disk space from 1258291200 limit

这个时候查询 dba_outstanding_alerts:

SQL> 0select reason,object_type,suggested_action from dba_outstanding_alerts. 

REASON OBJECT_TYPE SUGGESTED_ACTION 

------------------------------ --------------- ---------------------------------------- 

db_recovery_file_dest_size of RECOVERY AREA Add disk space and increase db_recovery_ 

1258291200 bytes is 88.20% use ile_dest_size, backup files to tertiary 

d and has 148509184 remaining device, 0delete files from recovery area 

bytes available. using RMAN, consider changing RMAN reten- 

tion policy or consider changing RMAN a 

rchivelog deletion policy. 

1 rows 0selected. 

SQL>

会给出相关的原因和建议的操作。

1.6. 注意事项

自动化的东西总是给人不确定性。如果您在测试环境中启用了闪回恢复区,那么一定要注意监控空间的使用。在生产数据库上使用(如果有这样的人的话),必须要把闪回恢复区放到单独的磁盘上。



相关文章


诊断性能问题:使用扩展SQL跟踪数据(2)
有关Oracle数据库10g中的分区功能
如何获得OracleDBA工作?(1)
简单谈谈Oracle10G中的闪回恢复区(1)
简单谈谈Oracle10G中的闪回恢复区(2)
简单介绍有关Oracle数据库备份技巧
Oracle等商家关注开源问题带来的冲击
[Oracle]分享:我的oracle9i学习笔记(9)
深刻理解Oracle数据库的启动和关闭
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛