1、首先要开归档,因为是热备份
(1)创建表空间
SQL> create tablespace lxtbs datafile '/u01/app/oracle/oradata/PROD/disk3/lxtbs01.dbf' size 50m;
SQL> select tablespace_name,contents,status from dba_tablespaces;
TABLESPACE_NAME CONTENTS STATUS
------------------------------ --------- ---------
SYSTEM PERMANENT ONLINE
UNDOTBS UNDO ONLINE
SYSAUX PERMANENT ONLINE
TEMPTS TEMPORARY ONLINE
LXTBS PERMANENT ONLINE
SQL> select file#,name from v$datafile;
FILE# NAME
---------- --------------------------------------------------
1 /u01/app/oracle/oradata/PROD/disk3/system01.dbf
2 /u01/app/oracle/oradata/PROD/disk4/undotbs01.dbf
3 /u01/app/oracle/oradata/PROD/disk4/sysaux01.dbf
4 /u01/app/oracle/oradata/PROD/disk3/lxtbs01.dbf
(2)让数据文件的scn号一致
SQL> select file#,checkpoint_change# from v$datafile;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 298164
2 298164
3 298164
4 299134 --不一致
SQL> alter system checkpoint; --生成全局检查点,写脏块
SQL> select file#,checkpoint_change# from v$datafile; --一致
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 299378
2 299378
3 299378
4 299378
(3)将之前创建的表空间设为只读
SQL> alter tablespace lxtbs read only; --只读
SQL> alter system checkpoint; --生成全局检查点
SQL> select file#,checkpoint_change# from v$datafile; --发现scn不一致,只有读写状态下才会一致
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 299473
2 299473
3 299473
4 299440
(4)备份失败的情况
SQL> alter tablespace lxtbs begin backup; --只读状态下备份,报错,因为它对数据文件加不上锁
SQL> alter tablespace lxtbs read write; --将表空间变为可写
SQL> alter system checkpoint; --生成全局检查点
SQL> select file#,checkpoint_change# from v$datafile; --一致
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 299628
2 299628
3 299628
4 299628
SQL> alter tablespace lxtbs begin backup; --开备份
SQL> shutdown immediate --不让关库
SQL> shutdown abort; --可以用abort关库
SQL> startup --启动失败,需要恢复表空间lxtbs;
SQL> recover tablespace lxtbs; --恢复表空间
SQL> alter database open; --启库
(5)备份成功
SQL> alter tablespace lxtbs begin backup; --备份
[oracle@gc1 ~]$ mkdir tbs_bak --创建目录
[oracle@gc1 ~]$ cd tbs_bak
[oracle@gc1 tbs_bak]$ pwd --路径
/home/oracle/tbs_bak
[oracle@gc1 tbs_bak]$ cp /u01/app/oracle/oradata/PROD/disk3/lxtbs01.dbf /home/oracle/tbs_bak --拷贝表空间文件
[oracle@gc1 tbs_bak]$ ls --查看
lxtbs01.dbf
SQL> alter tablespace lxtbs end backup; --结束备份
(6)假如在此时断电,文件也坏了,对其恢复:
SQL> shutdown abort --断电
[oracle@gc1 tbs_bak]$ rm /u01/app/oracle/oradata/PROD/disk3/lxtbs01.dbf
SQL> startup --启库失败
SQL> select file#,error from v$recover_file; --检查错误发生的范围
FILE# ERROR
---------- -----------------------------------------------------------------
4 FILE NOT FOUND
[oracle@gc1 tbs_bak]$ cp lxtbs01.dbf /u01/app/oracle/oradata/PROD/disk3/lxtbs01.dbf --备份转储
SQL> select file#,checkpoint_change# from v$datafile; --发现数据文件的scn号不样
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 340671
2 340671
3 340671
4 340797
SQL> recover datafile 4; --对数据文件进行恢复
SQL> alter database open; --启库
2、手工热备份实验
(1)开归档
(2)查看表空间
SQL> select tablespace_name,contents,status from dba_tablespaces;
TABLESPACE_NAME CONTENTS STATUS--------------- ------------------ ------------------SYSTEM PERMANENT ONLINEUNDOTBS1 UNDO ONLINESYSAUX PERMANENT ONLINETEMP TEMPORARY ONLINEUSERS PERMANENT ONLINEEXAMPLE PERMANENT ONLINEGOLDENGATE PERMANENT ONLINETBS_GGUSER PERMANENT ONLINE
SQL> select tablespace_name from dba_tablespaces where tablespace_name not like 'TMP%' and status='ONLINE';
TABLESPACE_NAME
---------------SYSTEMUNDOTBS1SYSAUXTEMPUSERSEXAMPLEGOLDENGATETBS_GGUSER我们要备份的是除临时表空间外的所有的online表空间
创建目录参考冷备
(3)写备份脚本
[oracle@gc2 prod_bak]$ vi hot_bak.sql
set echo off trimspool off heading off feedback off verify off time off
set pagesize 0 linesize 200
define bakdir='/home/oracle/prod_bak/hot_bak'
define bakscp='/home/oracle/prod_bak/hot_cmd.sql'
set serveroutput on
spool &bakscp
prompt alter system switch logfile;;
declare
cursor cu_tablespace is
select tablespace_name from dba_tablespaces where contents not like 'TEMP%' and status='ONLINE';
cursor cu_datafile(name varchar2) is
select file_name from dba_data_files where tablespace_name=name;
begin
for i in cu_tablespace loop
dbms_output.put_line('alter tablespace '||i.tablespace_name||' begin backup;');
for j in cu_datafile(i.tablespace_name) loop
dbms_output.put_line('host cp '||j.file_name||' &bakdir ');
end loop;
dbms_output.put_line('alter tablespace '||i.tablespace_name||' end backup;');
end loop;
dbms_output.put_line('alter database backup controlfile to trace;');
dbms_output.put_line('alter database backup controlfile to ''&bakdir/control01.ctl'';');
end;
/
spool off
@&bakscp
(4)跑脚本
SQL> @/home/oracle/prod_bak/hot_bak
可以看到生成了备份的中间脚本
[oracle@gc2 prod_bak]$ lshot_bak hot_bak.sql hot_cmd.sql
备份成功。