Home  >  Article  >  Database  >  Oracle控制文件新增,备份,恢复

Oracle控制文件新增,备份,恢复

WBOY
WBOYOriginal
2016-06-07 17:29:53902browse

控制文件实验 控制文件最多8个,至少1个,互为镜像,只要丢失了控制文件,数据库将无法正常关闭,无法启动。 //增加控制文件,必须

控制文件实验
 控制文件最多8个,至少1个,互为镜像,只要丢失了控制文件,数据库将无法正常关闭,无法启动。
 //增加控制文件,必须加上原有的控制文件,注意同一路径下的文件名不能相同
 alter system set control_files='/lvm/app/Oracle/oradata/updb/control01.ctl','/lvm/app/oracle/fast_recovery_area/updb/control02.ctl','/lvm/app/oracle/oradata/updb/control01a.ctl','/lvm/app/oracle/fast_recovery_area/updb/control02.ctl' scope=spfile;
 alter system set control_files='/lvm/app/oracle/oradata/updb/control01.ctl','/lvm/app/oracle/fast_recovery_area/updb/control02.ctl','/lvm/app/oracle/oradata/updb/control01a.ctl','/lvm/app/oracle/fast_recovery_area/updb/control02a.ctl' scope=spfile;
 

//复制原有的给新建的
 SQL> ho cp /lvm/app/oracle/oradata/updb/control01.ctl /lvm/app/oracle/oradata/updb/control01a.ctl
 SQL> ho cp /lvm/app/oracle/fast_recovery_area/updb/control02.ctl /lvm/app/oracle/fast_recovery_area/updb/control02a.ctl
 shutdown transactional
 startup
 

//减少控制文件
 alter system set control_files='/lvm/app/oracle/oradata/updb/control01.ctl','/lvm/app/oracle/fast_recovery_area/updb/control02.ctl' scope=spfile;
 

shutdown
 startup
 

//控制文件异常处理
 

先按照  的前两步建立好存储过程,再建立下面的过程
 //删除控制文件 df=8删除全部控制文件,df create or replace procedure foway_test_1(df number)
 as
 j number;
 begin
 j:=1;
 if df>8 or df  dbms_output.put_line('number can not gt 8 or lt 0');
 else
 

for i in(select name from v$controlfile) loop
    if length(i.name)>0 then
        if df=8 then
          del(i.name);
        else
          if j=df then
            del(i.name);
            exit;
          end if;
 

      end if;
      j:=j+1;
    end if;
 end loop;
 j:=1;
 end if;
 end;
 /
 
 1、启动时报告版本错误
    复制高版本的给低版本的
 2、控制文件部分丢失
    //先查看控制文件的信息
        SQL> select name from v$controlfile;
        select name from v$controlfile;
 

        NAME
        --------------------------------------------------------------------------------
        /lvm/app/oracle/oradata/updb/control01.ctl
        /lvm/app/oracle/fast_recovery_area/updb/control02.ctl
        /lvm/app/oracle/oradata/updb/control01a.ctl
        /lvm/app/oracle/fast_recovery_area/updb/control02a.ctl
      逐个 ls检查
      SQL> exec foway_test_1(1);
      exec foway_test_1(1);
     
      PL/SQL procedure successfully completed.
      再检查
      SQL> ho ls /lvm/app/oracle/oradata/updb/control01.ctl;
        ho ls /lvm/app/oracle/oradata/updb/control01.ctl;
        ls: cannot access /lvm/app/oracle/oradata/updb/control01.ctl: No such file or directory
      报告文件丢失
      shutdown abort; //强行关闭数据库,注意一定要关闭数据后进行操作,否则数据库将崩溃。
      复制存在的给丢失的
      ho cp /lvm/app/oracle/oradata/updb/control01a.ctl /lvm/app/oracle/oradata/updb/ control01.ctl
      startup
      完成恢复
      如果报告版本错误,复制高版本的给低版本的。
     
 3、控制文件全部丢失
  exec foway_test_1(8);
 
  a、数据库还未关闭
    //备份控制文件
    alter database backup controlfile to trace as '/tmp/c.sql';
    shutdown abort;
    //取出控制文件的建立脚本
    ho sed '1,/Set #2/p' -n /tmp/c.sql >/tmp/c1.sql;
    start /tmp/c1.sql;
    启动成功后马上进入rman target /
    backup database;
 
  b、数据库已经关闭但是rman有有效的备份(备份之后没有resetlogs,没有重建控制文件,没有clear logfile,当前数据库使用的日志文件没有丢失,时归档的)
    rman target /
    startup nomount;
    restore controlfile from '*s*备份文件';
    alter database mount;
    exit;
   
    sqlplus / as sysdba
    alter database backup controlfile to trace as '/tmp/c.sql' reuse;
    shutdown abort;
    //取出控制文件的建立脚本
    ho sed '1,/Set #2/p' -n /tmp/c.sql >/tmp/c1.sql;
    start /tmp/c1.sql;
    启动成功后马上进入rman target /
    backup database;

linux

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn