找回密码
 注册
搜索
热搜: 回贴
微赢网络技术论坛 门户 数据库 查看内容

对rman命令行为的操作简单分析

2009-12-14 18:41| 发布者: admin| 查看: 20| 评论: 0|原作者: 千年缘

△rman对dbms_backup.res......


  rman 对dbms_backup.restore 的一些特定调用完?梢酝ü??ebug 分析出来。
  通过设置debug 模式,我们可以跟踪到大量的Log,从而为分析提供一定的说明。假定我们提交如下的命令:
  rman target / debug trace=d:/rman_trace.log
  通过查看日志我们得之,rman 首先确定数据库状态:
  DBGSQL: EXEC SQL AT TARGET select decode(status,'OPEN',1,0) into :b1 from v$instance
  DBGSQL: sqlcode=0
  DBGSQL: :b1 = 1
  判断数据库是否是在open 状态下。然后,要去获取数据库的compatible参数值。
  接下来调用dbms_backup_restore确定rman 可用的版本信息。对应的一些参数如下:
  protocol_version_number_min NUMBER := 8;
  protocol_release_number_min NUMBER := 0;
  protocol_update_number_min NUMBER := 4;
  protocol_version_number_max NUMBER := 9;
  protocol_release_number_max NUMBER := 2;
  protocol_update_number_max NUMBER := 0;
  804-920 ,这个范围内可用,804 ? 920 ? 是不是很熟悉?
  下面调用dbms_rcvman的getPackageVersion 函数
  ($ORACLE_HOME/rdbms/admin/recover.bsq创建dbms_rcvman ,并可以获得相关注释)获取package 的版本可用信息。
  08.00.04到09.02.00
  接下来rman 会查询V$database ,从中获取name ,resetlogs_time ,resetlogs_change# ,dbid 等信息。
  下面这个比较重要, x$kcccp( Kernel Cache Checkpoint Progress)中获取检查点记录:
  类似如下的SQL:
  select nvl(max(cpmid),0) from x$kcccp where cpsta=2
  这些操作完成后,rman 从v$option 中获取相关信息,包括:'Parallel backup and recovery','Incremental backup and
  recovery','Duplexed backups','Block Media Recovery','Point-in-time tablespace recovery',通过这些来判断数据库是否具有这些
  功能。
  然后Log中显示连接到目标数据库。
  分析过程并不复杂,不过在涉及到深入的命令的时候会产生大量的Log,要有一定的耐心才能继续下去。在rman 出现故障的时候,
  设置Debug模式进行分析是一种非常有效的办法。如果可能得话,以后的文章中我会举几个例子来说明。

最新评论

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-30 01:38 , Processed in 0.153230 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

返回顶部