本节将演示下rman基于时间点的不完全恢复,修改过的数据有执行commit操作的事务,只要备份文件和联机重做日志或者归档日志文件存在,理论上都是可以恢复的
1:使用rman备份test表空间,test在oracle里面是一个保留关键字,所以备份的时候要加双引号
RMAN> backup tablespace "TEST" format '/u01/backup/test_1216.dbf' tag ts;
2:使用yang用户连接数据库实例,进行数据操作,改用户的默认表空间即为test
yang SQL>select default_tablespace from dba_users where username='YANG';
DEFAULT_TABLESPACE
------------------------------
TEST
yang SQL>conn yang/yang
Connected.
yang SQL>col object_name format a30;
yang SQL>select object_name,object_type from user_objects;
OBJECT_NAME OBJECT_TYPE
------------------------------ -------------------
TEST TABLE
yang SQL>select * from test order by 1;
ID NAME
---------- --------------------------------
1 one
2 two
3 three
3:插入一条新数据,并提交事务
yang SQL>insert into test values (4,'four');
1 row created.
yang SQL>commit;
Commit complete.
4:使用sys用户登录数据库,查看当前的联机日志组为组1
yang SQL>show user;
USER is "SYS"
yang SQL>select group#,status from v$log;
GROUP# STATUS
---------- ----------------
1 CURRENT
2 UNUSED
3 UNUSED
yang SQL>!strings /u01/app/oracle/oradata/yang/redo01.log |grep 'four' //在lgwr进程发生之前,记录是保存在redolog buffer中
yang SQL>!strings /u01/app/oracle/oradata/yang/redo01.log |grep 'four' //commit后,记录保存在当前active状态的联机重做日志文件中
four
yang SQL>!strings /u01/app/oracle/oradata/yang/test01.dbf |grep 'four'
yang SQL>alter system checkpoint; //在checkpoint发生后,记录才真实可靠的写入到数据文件中
System altered.
yang SQL>!strings /u01/app/oracle/oradata/yang/test01.dbf |grep 'four'
four,
5:继续更新一条记录,但不执行提交操作
yang SQL>insert into test values (5,'five');
1 row created.
yang SQL>select count(*) from test;
COUNT(*)
----------
5
6:记录正常时刻的系统时间,后面用来做恢复操作时使用,生产环境下如果遇到类似的情况,可以根据实际情况进行估计,通常使用logminer工具获取这个时间
yang SQL>select to_char(sysdate,'YYYY-MM-DD:HH24:MI:SS') as time from dual;
TIME
-------------------
2010-12-16:15:37:05
7:模拟数据丢失,这里就直接删除test表,在生产环境下,可能出现磁盘故障,用户误操作等情况使关键的数据丢失
yang SQL>drop table test;
Table dropped.
yang SQL>select count(*) from test;
select count(*) from test
*
ERROR at line 1:
ORA-00942: table or view does not exist
8:将数据库关闭,重新启动到mount状态,并使用rman进行恢复
yang SQL>conn /as sysdba
Connected.
yang SQL>shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
[oracle@rhel6 oradata]$ rman target /
Recovery Manager: Release 11.2.0.1.0 - Production on Thu Dec 16 16:01:43 2010
Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved.
connected to target database: YANG (DBID=3456695003, not open)
RMAN> startup mount;
Oracle instance started
database mounted
Total System Global Area 1068937216 bytes
Fixed Size 2220200 bytes
Variable Size 801115992 bytes
Database Buffers 260046848 bytes
Redo Buffers 5554176 bytes
RMAN> run {
2> allocate channel c1 type disk; //分配三个通道,提高并发
3> allocate channel c2 type disk;
4> allocate channel c3 type disk;
5> set until time "to_date('2010-12-16:15:37:05','YYYY-MM-DD:HH24:MI:SS')"; //指定恢复数据库状态的时间点
6> restore database; //还原数据库文件
7> recover database; //恢复数据库文件
8> alter database open resetlogs; //将数据库打到open状态,resetlogs参数将日志重新归位,使数据库的scn,检查点等保持一致
9> }
using target database control file instead of recovery catalog
allocated channel: c1
channel c1: SID=6 device type=DISK
allocated channel: c2
channel c2: SID=89 device type=DISK
allocated channel: c3
channel c3: SID=8 device type=DISK
executing command: SET until clause
Starting restore at 16-DEC-10
channel c1: starting datafile backup set restore
channel c1: specifying datafile(s) to restore from backup set
channel c1: restoring datafile 00001 to /u01/app/oracle/oradata/yang/system01.dbf
channel c1: restoring datafile 00002 to /u01/app/oracle/oradata/yang/sysaux01.dbf
channel c1: restoring datafile 00003 to /u01/app/oracle/oradata/yang/undotbs01.dbf
channel c1: restoring datafile 00004 to /u01/app/oracle/oradata/yang/users01.dbf
channel c1: restoring datafile 00006 to /u01/app/oracle/oradata/yang/backup_test1.dbf
channel c1: reading from backup piece /u01/backup/full_bak1216.dbf
channel c2: starting datafile backup set restore
channel c2: specifying datafile(s) to restore from backup set
channel c2: restoring datafile 00005 to /u01/app/oracle/oradata/yang/test01.dbf
channel c2: reading from backup piece /u01/backup/test_1216.dbf
channel c2: piece handle=/u01/backup/test_1216.dbf tag=TS
channel c2: restored backup piece 1
channel c2: restore complete, elapsed time: 00:00:03
channel c1: piece handle=/u01/backup/full_bak1216.dbf tag=FULL_BACKUP
channel c1: restored backup piece 1
channel c1: restore complete, elapsed time: 00:00:45
Finished restore at 16-DEC-10
Starting recover at 16-DEC-10
starting media recovery
archived log for thread 1 with sequence 1 is already on disk as file /u01/app/oracle/flash_recovery_area/YANG/archivelog/2010_12_16/o1_mf_1_1_6jmc341s_.arc
archived log file name=/u01/app/oracle/flash_recovery_area/YANG/archivelog/2010_12_16/o1_mf_1_1_6jmc341s_.arc thread=1 sequence=1
media recovery complete, elapsed time: 00:00:08
Finished recover at 16-DEC-10
database opened
released channel: c1
released channel: c2
released channel: c3
9:测试恢复数据
SQL>conn yang/yang
Connected.
yang SQL>desc test;
Name Null? Type
----------------------------------------- -------- ----------------------------
ID NUMBER(38)
NAME VARCHAR2(32)
yang SQL>select * from test;
ID NAME
---------- --------------------------------
3 three
1 one
2 two
4 four