oracle数据库热备中的备份和恢复及例子
手工热备(开库状态)
备份控制文件:
alter database backup controlfile to '/u01/oradata/prod/con.bak1';
备份数据文件(这里用到pl/sql进行批处理,将查询结果粘贴运行即可)
begin
for i in (select tablespace_name from dba_tablespaces) loop
dbms_output.put_line('alter tablespace '||i.tablespace_name||' begin backup;');
for j in (select file_name from dba_data_files where tablespace_name=i.tablespace_name) loop
dbms_output.put_line('host cp '||j.file_name||' /home/oracle/hot_backup');
end loop;
dbms_output.put_line('alter tablespace '||i.tablespace_name||' end backup;');
end loop;
end;
模拟现场,举例
1.删除emp1表 drop table emp1 purge;(不完全恢复)
模拟:
drop table emp1 purge;
select * from v$log;
alter system switch logfile;
/
解决:
select name from v$archived_log;(可以看到删除的日志条目切换到此归档日志里了)
/u01/flash_recovery_area/PROD/archivelog/2017_08_13/o1_mf_1_6_drzyyodl_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_08_27/o1_mf_1_7_dt4yy16z_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_08_27/o1_mf_1_8_dt4zlzff_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_08_27/o1_mf_1_9_dt4zow6g_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_08_27/o1_mf_1_1_dt5fpkxt_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_11_12/o1_mf_1_2_f0jh6xf2_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_11_12/o1_mf_1_3_f0jk4n4p_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_11_13/o1_mf_1_1_f0lkgyt6_.arc
/u01/flash_recovery_area/PROD/archivelog/2017_11_13/o1_mf_1_2_f0lo0fom_.arc
因为今天13号所以选这两条日志,也可以多切换几次日志多生成几个日志条目
接下来进行时间的挖掘(基于时间点来恢复)
mkdir -p /home/oracle/logmnr
show parameter utl_file_dir
alter system set utl_file_dir='/home/oracle/logmnr' scope=spfile;
startup force;
show parameter utl_file_dir;
alter database add supplemental log data;
execute dbms_logmnr_d.build('dict.ora','/home/oracle/logmnr',dbms_logmnr_d.store_in_flat_file);
execute dbms_logmnr.add_logfile(logfilename=>'/u01/flash_recovery_area/PROD/archivelog/2017_11_13/o1_mf_1_1_f0lkgyt6_.arc',options=>dbms_logmnr.new);
execute dbms_logmnr.add_logfile(logfilename=>'/u01/flash_recovery_area/PROD/archivelog/2017_11_13/o1_mf_1_2_f0lo0fom_.arc',options=>dbms_logmnr.addfile);
execute dbms_logmnr.start_logmnr(dictfilename=>'/home/oracle/logmnr/dict.ora',options=>dbms_logmnr.ddl_dict_tracking);
select username,scn,to_char(timestamp,'yyyy-mm-dd hh24:mi:ss') time,sql_redo from v$logmnr_contents WHERE lower(sql_redo) like 'drop table%';
execute dbms_logmnr.end_logmnr;
USERNAME SCN TIME
------------------------------ ---------- -------------------
SQL_REDO
------------------------------------------------------------
UNKNOWN 954522 2017-11-13 16:03:53
drop table emp1 purge;
(记录此时间2017-11-13 16:03:53)
shutdown abort;
时间挖掘完成。
cd /home/oradata/prod
rm *.dbf
cp /home/oracle/hot_backup/*.dbf ./
startup;
recover database until time '2017-11-13 16:03:53';auto
alter database open resetlogs;
验证查看
select * from emp1;
成功找回此表,同样可以通过scn号寻找恢复,但是不能用闪回表因为我是purge彻底删除,只能不完全恢复。
2.模拟user01.dbf 介质损坏
rm -rf /u01/oradata/prod/users01.dbf
例如shutdown immediate
SYS@prod>shutdown immediate
ORA-01116: 打开数据库文件 4 时出错
ORA-01110: 数据文件 4: '/u01/oradata/prod/users01.dbf'
ORA-27041: 无法打开文件
解决:
alter system flush buffer_cache;
alter tablespace users offline immediate;
cp /home/oracle/hot_backup/users01.dbf /u01/oradata/prod/
recover tablespace users;auto
alter tablespace users online;
3.模拟undotbs1 介质损坏(恢复的方法多种我只演示根据文件号恢复)
select name from v$datafile;
rm -rf /u01/oradata/prod/undotbs01.dbf
shutdown abort
解决:
SYS@prod>select FILE#,ERROR from v$recover_file;
FILE# ERROR
---------- -----------------------------------------------------------------
1 UNKNOWN ERROR
2 UNKNOWN ERROR
3 FILE NOT FOUND
SYS@prod>select FILE#,NAME from v$datafile;
FILE# NAME
--------------------------------------------------
1 /u01/oradata/prod/system01.dbf
2 /u01/oradata/prod/sysaux01.dbf
3 /u01/oradata/prod/undotbs01.dbf
4 /u01/oradata/prod/users01.dbf
5 /u01/oradata/prod/example01.dbf
SYS@prod>select file#,checkpoint_change# from v$datafile_header;
FILE# CHECKPOINT_CHANGE#
---------- ------------------
1 975649
2 975649
3 0
4 975649
5 975649
确定3号文件损坏
cp /home/oracle/hot_backup/undotbs01.dbf /u01/oradata/prod/
recovere datafile 3;auto
alter database open;
4.当前日志,介质损坏
create table t2(id int);
insert into t2 values(100);
commit;
alter system archive log current;
insert into t2 values(200);
commit;
select * from scott.t2;
select group#,sequence#,status from v$log;
select GROUP#,MEMBER from v$logfile;
查出当前的日志是组号是1对应的redo01.log
模拟 rm -rf /u01/oradata/prod/redo01.log
shutdown abort
startup
数据库装载完毕。
ORA-00313: 无法打开日志组 1 (用于线程 1) 的成员 ORA-00312:
联机日志 1 线程 1: '/u01/oradata/prod/redo01.log'
ORA-27037: 无法获得文件状态 Linux
Error: 2: No such file or directory
Additional information: 3
解决:
cd /u01/oradata/prod/
rm *.dbf
cp /home/oracle/hot_backup/*.dbf ./
startup
recover database until cancel;auto
recover database until cancel;cancel
alter database open resetlogs;
select * from scott.t1;
ID
----------
100
5.控制文件损坏
rm -rf /u01/oradata/prod/control01.ctl
rm -rf /u01/flash_recovery_area/prod/control02.ctl
shutdown abort
startup
ORA-00205: ?????????, ??????, ???????
select status from v$instance;
解决:
cp /home/oracle/control01.ctl /u01/oradata/prod/
cp /home/oracle/control02.ctl /u01/flash_recovery_area/prod/
recover database using backup controlfile;auto
recover database using backup controlfile;当前的日志
alter database open resetlogs;
oracle数据库热备中的备份和恢复及例子的更多相关文章
- oracle数据库冷备中的手工备份和恢复
我的操作系统是red hat5.5 32位系统oracle11g 以我的系统为例: 冷备状态下,数据库必须是关闭的,但是我们现在要做一个实验,在开库的状态下分别查询出: 1.show paramete ...
- mysql5.6数据库双机热备、主从备份
主题:mysql5.6数据库双机热备.主从备份 缘由: 在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一.尤其是在大规模系统中,数据库集群已经成为必备的配置之一.集群的好处主要有:查询 ...
- MySQL数据库双机热备------主-主备份配置
MySQL数据库双机热备------主-主备份配置 实验环境: 主1数据库 192.168.1.1 centos6.5 x86_64 +MySQL5.5.35 主2数据库192.168.1.2 Wi ...
- oracle双机热备概念
1. 双机热备概述 双机热备有两种实现模式,一种是基于共享的存储设备的方式,另一种是没有共享的存储设备的方式,一般称为纯软件方式. 基于存储共享的双机热备是双机热备的最标准方案. ...
- Oracle:热备测试
我们知道Oracle数据库热备有3步: 1. alter tablespace tbname begin backup: 2. cp /××× to /×× 3. alter ta ...
- 部署web01,web02,nfs,db01,backup,搭建wordpress,WeCenter,实现共享,热备,实时备份
小结 部署web01,web02,nfs,db01,backup,搭建wordpress,WeCenter,实现共享,热备,实时备份 1)在web01和web02上安装nginx和php 2)创建ww ...
- Oracle数据库误删文件导致rman备份报错RMAN-06169解决办法
Oracle数据库误删文件导致rman备份报错RMAN-06169解决办法 可能是误删文件导致在使用rman备份时候出现以下提示 RMAN-06169: could not read file hea ...
- oracle 双机热备,oracle dataguard 和oracle rac的区别和联系(转)
Data Guard 是Oracle的远程复制技术,它有物理和逻辑之分,但是总的来说,它需要在异地有一套独立的系统,这是两套硬件配置可以不同的系统,但是这两套系统的软件结构保持一致,包括软件的版本,目 ...
- Oracle数据库三种标准的备份方法
Oracle数据库的三种标准的备份方法: 1.导出/导入(EXP/IMP). 2.热备份. 3.冷备份. 注释:导出备件是一种逻辑备份,冷备份和热备份是物理备份. 一.导出/导入(Export/Imp ...
随机推荐
- 【bzoj2761】[JLOI2011]不重复数字
给出N个数,要求把其中重复的去掉,只保留第一次出现的数. 例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 18 3 19 6 5 4. Inpu ...
- unserialize() [function.unserialize]: Error at offset
$a = 'a:1:{i:0;s:12:"1,10,93,";}'; var_dump( unserialize( $a ) ); 运行之后页面上显示Notice: unseria ...
- 小程序解释HTML富文本的两种办法
今天写着着代码,读取数据库的内容时突然跳出"<span>.<p>. "这些HTML标签.字符,吓一跳:本来如果是写HTML.JS倒也没什么,但是我在写小程序 ...
- 【MVC】会员注册/登录,普通验证,会员名是否注册Ajax验证以及会员邮件验证实现原理
using System; using System.Collections.Generic; using System.ComponentModel; using System.ComponentM ...
- Sql语句构造类,多字段新增或修改时,拼装sql语句比较方便
using System; using System.Collections.Generic; using System.Text; namespace MSCL { #region 使用示例 /* ...
- 彻底区分html的attribute与dom的property
当初在学html时始终没有弄清楚的关于attribute与property的区别,竟然在看angular文档时弄明白了. angular官方文档的数据绑定一节提到html attribute与dom ...
- Java常用类(一)String类详解
前言 在我们开发中经常会用到很多的常用的工具类,这里做一个总结.他们有很多的方法都是我们经常要用到的.所以我们一定要把它好好的掌握起来! 一.String简介 1.1.String(字符串常量)概述 ...
- LINUX 笔记-free命令
free命令可以显示Linux系统中空闲的.已用的物理内存及swap内存,及被内核使用的buffer. focus@ubuntu:~$ free -h total used free shared b ...
- 动态主机配置协议DHCP
一.什么是DHCP DHCP,动态主机配置协议,提供一种称为“即插即用连网”的机制,允许一台计算机加入新的网络和获取IP地址而不用手工配置. 二.DHCP工作原理和工作流程 DHCP服务器被动打开UD ...
- Appium python自动化测试系列之自动化截图(十一)
11.1 截图函数的正常使用 11.1.1 截图方法 无论是在手动测试还是自动化测试中场景复现永远是一个很重要的事情,有时候一些问题可能很难复现,这个都需要测试人员对bug有很高的敏感度,在一般的情况 ...