一、冷备份实验模拟当机,加归档补齐
实验步骤: 1.查看要备份的数据文件 SQL> select name from v$datafile;NAME
-------------------------------------------------------------------------------- /oracle/oradata/zwb/system01.dbf /oracle/oradata/zwb/undotbs01.dbf /oracle/oradata/zwb/sysaux01.dbf /oracle/oradata/zwb/users01.dbf /oracle/oradata/zwb/example01.dbf2、查看要备份的控制文件
SQL> select name from v$controlfile;NAME
-------------------------------------------------------------------------------- /oracle/oradata/zwb/control01.ctl /oracle/oradata/zwb/control02.ctl /oracle/oradata/zwb/control03.ctl3.查看要备份的日志文件
SQL> select member from v$logfile;MEMBER
-------------------------------------------------------------------------------- /oracle/oradata/zwb/redo03.log /oracle/oradata/zwb/redo02.log /oracle/oradata/zwb/redo01.log4、查看是否归档模式,没有设为归档
SQL> archive log list Database log mode Archive Mode Automatic archival Enabled Archive destination /oracle/archlog Oldest online log sequence 17 Next log sequence to archive 19 Current log sequence 195、关数据库
SQL> shutdown immediate6、开始备份
[oracle@testsvr bak]$ cd /oracle/oradata/zwb/ [oracle@testsvr zwb]$ cp * /oracle/bak ---备份至/oracle/bak7、开启数据库,切归档
[oracle@testsvr bak]$ sqlplus '/as sysdba' SQL> startup SQL> alter system switch logfile;System altered.
8、换用户做事
SQL> conn zwb/zwb Connected. SQL> create table t1 as select * from v$bh; ---随便创建表格Table created.
SQL> select count(*) from t1; ---看一下建的表的数据
COUNT(*)
---------- 49599、连续插数据再切归档,提交
SQL> insert into t1 select * from t1;4959 rows created.
SQL> alter system switch logfile;
System altered.
SQL> commit;
Commit complete.
SQL> insert into t1 select * from t1;9918 rows created.
SQL> commit;
Commit complete.
SQL> alter system switch logfile;
System altered.
10、假设此时数据库当机
SQL> select count(*) from t1; --当之前的数据
COUNT(*)
---------- 19836 ***************************************SQL> insert into t1 select * from t1; --再插数据
19836 rows created.
SQL> commit;
Commit complete.
SQL> select count(*) from t1; ---当后的数据放在redolog里COUNT(*)
---------- 39672 11、查看最后更改值存放在哪里,由于是存放在CURRENT redolog里,所以是存放在2号文件SQL> select * from v$log ;
GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS
---------- ---------- ---------- ---------- ---------- --- ---------------- FIRST_CHANGE# FIRST_TIM ------------- --------- 1 1 26 52428800 1 YES ACTIVE 751890 23-MAY-122 1 27 52428800 1 NO CURRENT
751893 23-MAY-123 1 25 52428800 1 YES ACTIVE
751772 23-MAY-12即如果/oracle/oradata/zwb/redo02.log 数据损坏,最后插的数据永远丢失
*************************************************** 此时当机12、当机
SQL> shutdown abort; ORA-01031: insufficient privileges SQL> conn /as sysdba Connected. SQL> shutdown abort; ORACLE instance shut down. 13、模拟数据文件、控制文件、日志文件由于当机均丢失 [oracle@testsvr bak]$ pwd ---进入备份目录 /oracle/bak[oracle@testsvr zwb]$ pwd
/oracle/oradata/zwb [oracle@testsvr zwb]$ rm -rf * [oracle@testsvr zwb]$ ls -rtl total 014、将之前的冷备份恢复
[oracle@testsvr bak]$ pwd /oracle/bak [oracle@testsvr bak]$ cp * /oracle/oradata/zwb[oracle@testsvr zwb]$ ls -rtl --查看已恢复
total 1090552 -rw-r----- 1 oracle oinstall 7061504 May 23 23:43 control01.ctl.beifen -rw-r----- 1 oracle oinstall 7061504 May 23 23:43 control01.ctl.bak -rw-r----- 1 oracle oinstall 7389184 May 23 23:43 control01.ctl -rw-r----- 1 oracle oinstall 7389184 May 23 23:43 control03.ctl -rw-r----- 1 oracle oinstall 7389184 May 23 23:43 control02.ctl -rw-r----- 1 oracle oinstall 104865792 May 23 23:43 example01.dbf -rw-r----- 1 oracle oinstall 52429312 May 23 23:43 redo01.log -rw-r----- 1 oracle oinstall 52429312 May 23 23:43 redo02.log -rw-r----- 1 oracle oinstall 7061504 May 23 23:43 standby01 -rw-r----- 1 oracle oinstall 52429312 May 23 23:43 redo03.log -rw-r----- 1 oracle oinstall 251666432 May 23 23:44 sysaux01.dbf -rw-r----- 1 oracle oinstall 503324672 May 23 23:44 system01.dbf -rw-r----- 1 oracle oinstall 5251072 May 23 23:44 users01.dbf -rw-r----- 1 oracle oinstall 31465472 May 23 23:44 undotbs01.dbf -rw-r----- 1 oracle oinstall 20979712 May 23 23:44 temp01.dbf15、读归档
SQL> startup mount; ORACLE instance started.SQL> recover database; ---不行
ORA-00283: recovery session canceled due to errors ORA-00264: no recovery required SQL> recover database using backup controlfile; ---补齐归档16、最终查看
SQL> alter database open read only; ---需要不完全恢复 alter database open read only * ERROR at line 1: ORA-16004: backup database requires recovery ORA-01113: file 1 needs media recovery ORA-01110: data file 1: '/oracle/oradata/zwb/system01.dbf' SQL> recover database using backup controlfile until cancel; ----不完全恢复 ORA-00279: change 751893 generated at 05/23/2012 23:23:00 needed for thread 1 ORA-00289: suggestion : /oracle/archlog/1_27_765904367.dbf ORA-00280: change 751893 for thread 1 is in sequence #27 Specify log: {<RET>=suggested | filename | AUTO | CANCEL} cancel
SQL> conn zwb/zwb ---最终查看结果
Connected. SQL> select count(*) from t1;COUNT(*)
---------- 19836 结论:当机前未归档的数据丢失
二、裸设备上做冷备:(以备份1号数据文件为例)
1、SQL> select file#,name,bytes from v$datafile; ---查出1号数据文件大小FILE# NAME BYTES
---------- ---------------------------------------- ---------- 1 /oracle/oradata/zwb/system01.dbf 503316480 2 /oracle/oradata/zwb/undotbs01.dbf 31457280 3 /oracle/oradata/zwb/sysaux01.dbf 251658240 4 /oracle/oradata/zwb/users01.dbf 17039360 5 /oracle/oradata/zwb/example01.dbf 104857600 2、[oracle@testsvr ~]$ ls -l /oracle/oradata/zwb/system01.dbf ---系统上的大小 -rw-r----- 1 oracle oinstall 503324672 May 25 23:08 /oracle/oradata/zwb/system01.dbf 3、SQL> select 503324672-503316480 from dual; --相差8192,是操作系统头503324672-503316480
------------------- 81924、SQL> select (503316480+8192)/8192 from dual; ---count的值
(503316480+8192)/8192
--------------------- 61441 SQL> select TABLESPACE_NAME,BLOCK_SIZE from dba_tablespaces; ---bs来源TABLESPACE_NAME BLOCK_SIZE
------------------------------ ---------- SYSTEM 8192 UNDOTBS1 8192 SYSAUX 8192 TEMP 8192 USERS 8192 EXAMPLE 8192 5、[oracle@testsvr ~]$ dd if=/oracle/oradata/zwb/system01.dbf of=/oracle/bak/system01.dbf.bak bs=8192 count=61441 ---用DD命令备份 注意点:AIX裸设备还有4K的访问头