首页 > 数据库 >NBU上Oracle数据库恢复演练手册

NBU上Oracle数据库恢复演练手册

时间:2023-04-03 17:22:23浏览次数:44  
标签:datafile testtest DG NBU test oradata Oracle DATA 演练

目录
2. 1|01.1 Oracle数据库恢复 4
3.1 1|11.1.1 安装新的客户端 6
3.2 1|21.1.2 新建异机恢复文件 6
3.3 1|31.1.3 新建数据库实例 6
3.4 1|41.1.4 建立spfile文件 6
3.5 1|51.1.5 建立数据文件夹 11
3.6 1|61.1.6 启动数据库到nomount状态 12
3.7 1|71.1.7 列出备份信息 13
3.8 1|81.1.8 还原controlfile,并mount数据库 13
3.9 1|91.1.9 查找数据文件信息 15
3.10 1|101.1.10 数据文件恢复 17
3.11 1|111.1.11 归档日志恢复 20
3.12 1|121.1.12 联机日志路径修改 23
3.13 1|131.1.13 Recover并打开数据库 24
3.14 1|141.1.14 验证数据库 25

3.11|11.1.1 安装新的客户端
 
在备份服务器上添加hosts信息
 
IP地址 客户端
{NBU Master IP地址} {NBU Master主机名}

解压NBU客户端安装包并运行安装程序,安装客户端
 
3.21|21.1.2 新建异机恢复文件
 
在备份服务器上建立支持异机恢复要求的文件。
备份服务器建立No.Restrictions空文件
Windows platform: InstallPath\netbackup\db\altnames\No.Restrictions
 UNIX platform: /usr/openv/netbackup/db/altnames/No.Restrictions
3.31|31.1.3 新建数据库实例
 
对于需要恢复的机器,需要新建立一个数据库实例进行数据恢复。
 
本次恢复针到的实例为test
 
3.41|41.1.4 建立spfile文件
 
原spfile导出文件为:
[root@backup-test testtest]# cat inittest1.ora.old
test2.__db_cache_size=7918845952
test1.__db_cache_size=6643777536
test2.__java_pool_size=134217728
test1.__java_pool_size=134217728
test2.__large_pool_size=167772160
test1.__large_pool_size=167772160
test1.__oracle_base='/oracle/'#ORACLE_BASE set from environment
test2.__oracle_base='/oracle/'#ORACLE_BASE set from environment
test2.__pga_aggregate_target=6442450944
test1.__pga_aggregate_target=5637144576
test2.__sga_target=9663676416
test1.__sga_target=10468982784
test2.__shared_io_pool_size=0
test1.__shared_io_pool_size=0
test2.__shared_pool_size=1342177280
test1.__shared_pool_size=3422552064
test2.__streams_pool_size=0
test1.streams_pool_size=0
*.audit_file_dest='/oracle/admin/test/adump'
*.audit_trail='db'
*.cluster_database=true
*.compatible='11.2.0.4.0'
*.control_files='+DATA_DG/test/controlfile/current.256.834077963','+DATA_DG/test/controlfile/current.275.834330051','+FLASH_DG/test/controlfile/current.278.834330403'
*.db_block_size=8192
*.db_create_file_dest='+DATA_DG'
*.db_domain=''
*.db_name='test'
*.diagnostic_dest='/oracle'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=testXDB)'
test1.instance_number=1
test2.instance_number=2
*.lock_sga=FALSE
*.log_archive_dest_1='LOCATION=+FLASH_DG'
*.log_archive_format='%t
%s
%r.dbf'
*.memory_max_target=16106127360
*.memory_target=16106127360
*.open_cursors=500
*.processes=1000
*.remote_listener='test-scan:1521'
*.remote_login_passwordfile='exclusive'
*.session_cached_cursors=100
*.sessions=1105
test2.thread=2
test1.thread=1
*.undo_retention=7200
test1.undo_tablespace='UNDOTBS1'
test2.undo_tablespace='UNDOTBS2'
 
 
由于需要恢复到单机,删除RAC相关信息。 另外由于硬件资源的不同,删除需要恢复的资源配置。
新的配置文件为
[root@backup-test testtest]# cat inittest1.ora
*.__oracle_base='/oradata/testtest/'#ORACLE_BASE set from environment
*.__pga_aggregate_target=5637144576
*.sga_target=10468982784
*.audit_file_dest='/oradata/testtest/adump'
*.audit_trail='db'
*.compatible='11.2.0.4.0'
*.control_files='/oradata/testtest/controlfile/current.256.834077963'
*.db_block_size=8192
*.db_create_file_dest='/oradata/testtest/'
*.db_domain=''
*.db_name='test'
*.diagnostic_dest='/oradata/testtest/'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=testXDB)'
*.lock_sga=FALSE
*.log_archive_dest_1='LOCATION=/oradata/testtest/archive/'
*.log_archive_format='%t
%s
%r.dbf'
*.open_cursors=500
*.processes=1000
*.remote_login_passwordfile='exclusive'
*.session_cached_cursors=100
*.sessions=1105
*.undo_retention=7200
*.undo_tablespace='UNDOTBS1'
 
 
3.51|51.1.5 建立数据文件夹
 
根据spfile建立相关文件
[root@backup-test testtest]# ll -a
total 52
drwxrwxrwx  7 oracle oinstall  4096 Sep 25 16:26 .
drwxrwxr-x 29 oracle oinstall 12288 Sep 28 10:03 ..
drwxr-xr-x  2 oracle oinstall  4096 Sep 28 10:37 adump
drwxr-xr-x  2 oracle oinstall  4096 Sep 25 16:02 archive
drwxr-xr-x  2 oracle oinstall  4096 Sep 28 10:10 controlfile
drwxrwxr-x  3 oracle oinstall  4096 Sep 25 16:20 diag
-rwxrwxrwx  1 oracle oinstall   760 Sep 25 16:26 inittest1.ora
-rwxr-xr-x  1 oracle oinstall  1578 Sep 25 15:45 inittest1.ora.old
drwxrwxrwx  2 oracle oinstall  4096 Sep 25 12:04 testtest
-rwxrwxrwx  1 oracle oinstall  6520 Sep 25 14:44 utlpwdmg.sql
 
 
3.61|61.1.6 启动数据库到nomount状态
sqlplus /nolog
idle> conn / as sysdba
idle> startup nomount pfile='/oradata/testtest/inittest1.ora'
 
idle> startup nomount pfile='/oradata/testtest/inittest1.ora'
ORACLE instance started.
 
Total System Global Area  396726272 bytes
Fixed Size                  2253504 bytes
Variable Size             318770496 bytes
Database Buffers           67108864 bytes
Redo Buffers                8593408 bytes
 
 
3.71|71.1.7 列出备份信息
在备份服务器上列出相关备份信息
bplist -C test-db01 -s 09/27/2015  -t 4 -R -b -l /
。。。。。。。
 
 
3.81|81.1.8 还原controlfile,并mount数据库
RMAN还原
RMAN>
RMAN>connect target /
RMAN> run{
2> allocate channel ch0 type 'sbt_tape';
3> send 'NB_ORA_CLIENT=test-db01';
4> send 'nb_ora_serv=nbu-b';
5> restore controlfile from '/cntrl_3175_1_891580028';
6> release channel ch0;
7> }
 
using target database control file instead of recovery catalog
allocated channel: ch0
channel ch0: SID=578 device type=SBT_TAPE
channel ch0: Veritas NetBackup for Oracle - Release 7.6 (2014102721)
 
sent command to channel: ch0
 
sent command to channel: ch0
 
Starting restore at 2015-09-28 10:10:36
 
channel ch0: restoring control file
channel ch0: restore complete, elapsed time: 00:00:15
output file name=/oradata/testtest/controlfile/current.256.834077963
Finished restore at 2015-09-28 10:10:52
 
released channel: ch0
 
RMAN> alter database mount;
 
database mounted
 
 
3.91|91.1.9 查找数据文件信息
sqlplus /nolog
idle> conn / as sysdba
 
idle> select name from v$datafile;
 
NAME

+DATA_DG/test/datafile/system.259.834077963
+DATA_DG/test/datafile/sysaux.260.834077967
+DATA_DG/test/datafile/undotbs1.261.834077971
+DATA_DG/test/datafile/undotbs2.263.834077979
+DATA_DG/test/datafile/users.264.834077981
+DATA_DG/test/datafile/zhos_dataspace.268.889894605
+DATA_DG/test/datafile/zhos_dataspace.272.834956161
+DATA_DG/test/datafile/zhos_dataspace.271.834956199
+DATA_DG/test/datafile/spcred_dataspace.269.834956241
+DATA_DG/test/datafile/zhos_indexspace.273.834317857
+DATA_DG/test/datafile/audit_dataspace.280.846839715
 
11 rows selected.
 
idle> select member from v$logfile;
 
MEMBER

+DATA_DG/test/onlinelog/group_1.257.834077963
+DATA_DG/test/onlinelog/group_2.258.834077963
+DATA_DG/test/onlinelog/group_3.265.834080437
+DATA_DG/test/onlinelog/group_4.266.834080437
+DATA_DG/test/onlinelog/group_5.276.834332677
+DATA_DG/test/onlinelog/group_6.277.834332723
+DATA_DG/test/onlinelog/group_7.278.834332751
+DATA_DG/test/onlinelog/group_8.279.834332783
 
8 rows selected.
 
 
3.101|101.1.10 数据文件恢复
 
编辑还原脚本如下:
export ORACLE_SID=test
rman  <<EOF          
connect target /                                     
run {                                                
allocate channel ch0 type 'SBT_TAPE';
allocate channel ch1 type 'SBT_TAPE';
send 'nb_ora_serv=nbu-b';
send 'nb_ora_client=test-db01';
set newname for datafile '+DATA_DG/test/datafile/system.259.834077963' to '/oradata/testtest/system.259.834077963';
set newname for datafile '+DATA_DG/test/datafile/sysaux.260.834077967' to '/oradata/testtest/sysaux.260.834077967';
set newname for datafile '+DATA_DG/test/datafile/undotbs1.261.834077971' to '/oradata/testtest/undotbs1.261.834077971';
set newname for datafile '+DATA_DG/test/datafile/undotbs2.263.834077979' to '/oradata/testtest/undotbs2.263.834077979';
set newname for datafile '+DATA_DG/test/datafile/users.264.834077981' to '/oradata/testtest/users.264.834077981';
set newname for datafile '+DATA_DG/test/datafile/zhos_dataspace.268.889894605' to '/oradata/testtest/zhos_dataspace.268.889894605';
set newname for datafile '+DATA_DG/test/datafile/zhos_dataspace.272.834956161' to '/oradata/testtest/zhos_dataspace.272.834956161';
set newname for datafile '+DATA_DG/test/datafile/zhos_dataspace.271.834956199' to '/oradata/testtest/zhos_dataspace.271.834956199';
set newname for datafile '+DATA_DG/test/datafile/spcred_dataspace.269.834956241' to '/oradata/testtest/spcred_dataspace.269.834956241';
set newname for datafile '+DATA_DG/test/datafile/zhos_indexspace.273.834317857' to '/oradata/testtest/zhos_indexspace.273.834317857';
set newname for datafile '+DATA_DG/test/datafile/audit_dataspace.280.846839715' to '/oradata/testtest/audit_dataspace.280.846839715';
restore database;
switch datafile all;
release channel ch0;
release channel ch1;
}
exit
EOF
 
运行数据还原
 recover database;
 
恢复完成
 
3.111|111.1.11 归档日志恢复
 
idle> select THREAD#,SEQUENCE#,FIRST_TIME,COMPLETION_TIME from v$archived_log where  COMPLETION_TIME>to_date('20150927 20:00:00','yyyymmdd hh24:mi:ss') and  COMPLETION_TIME<to_date('20150928 6:00:00','yyyymmdd hh24:mi:ss') order by SEQUENCE#;
 
   THREAD#  SEQUENCE# FIRST_TIME          COMPLETION_TIME


1      27587 2015-09-27 19:59:31 2015-09-27 21:01:28
         ......
 
39 rows selected.
RMAN还原归档日志
节点1还原
RMAN> connect target /
 
connected to target database: test (DBID=825185095, not open)
 
RMAN> run{
set archivelog destination to '/oradata/testtest/archive';
2> 3> allocate channel ch0 type 'SBT_TAPE';
send 'NB_ORA_CLIENT=test-db01';
send 'nb_ora_serv=nbu-b';
restore archivelog  sequence between 27587 and 27597 thread 1;
4> 5> 6> 7> release channel ch0;
8> }
 
executing command: SET ARCHIVELOG DESTINATION
 
......
 
released channel: ch0
节点2还原
RMAN> run{      
set archivelog destination to '/oradata/testtest/archive';
2> 3> allocate channel ch0 type 'SBT_TAPE';
4> send 'NB_ORA_CLIENT=test-db01';
5> send 'nb_ora_serv=nbu-b';
6> restore archivelog  sequence between 45287 and 45314 thread 2;
7> release channel ch0;
8> }
 
executing command: SET ARCHIVELOG DESTINATION
 
allocated channel: ch0
channel ch0: SID=673 device type=SBT_TAPE
channel ch0: Veritas NetBackup for Oracle - Release 7.6 (2014102721)
 
sent command to channel: ch0
 
sent command to channel: ch0
 
Starting restore at 2015-09-28 14:14:04
 
channel ch0: starting archived log restore to user-specified destination
......
released channel: ch0
 
 
3.121|121.1.12 联机日志路径修改
Sqlplus 修改
idle>
alter database rename file '+DATA_DG/test/onlinelog/group_1.257.834077963' to'/oradata/testtest/group_1.257.834077963';
......
 
3.131|131.1.13 Recover并打开数据库
Sqlplus启动数据库
idle> recover database until cancel using backup controlfile;
ORA-00279: change 10315737932005 generated at 09/27/2015 22:03:45 needed for thread 1
ORA-00289: suggestion : /oradata/testtest/archive/1_27589_834077959.dbf
ORA-00280: change 10315737932005 for thread 1 is in sequence #27589
 
 
Specify log: {=suggested | filename | AUTO | CANCEL}
AUTO
ORA-00308: cannot open archived log '/oradata/testtest/archive/1_27589_834077959.dbf'
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3
 
 
..............
 
ORA-00308: cannot open archived log '/oradata/testtest/archive/2_45315_834077959.dbf'
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3
 
idle>
idle> alter database open resetlogs;
 
Database altered.
 
 
 
3.141|141.1.14 验证数据库
 
idle>  select open_mode from v$database;
 
OPEN_MODE

READ WRITE

标签:datafile,testtest,DG,NBU,test,oradata,Oracle,DATA,演练
From: https://www.cnblogs.com/Gatsbysun/p/17283707.html

相关文章

  • Oracle11G安装在Linux7.下版本上BUG处理
    1.Java页面框无法拖拽拉伸,需要加上jre环境变量./runInstaller-jreLoc/usr/lib/jvm/jre-1.8.02.安装执行到68%左右时报错解决方法:cd$ORACLE_HOME/sysman/libcpins_emagent.mkins_emagent.mk.bakviins_emagent.mk搜索:/NMECTL后面加上-lnnz11继续安装即可......
  • 7.Oracle里的常见的执行计划
    索引唯一扫描:indexuniquescanscott@ORCLPDB012023-04-0222:44:32>createtableemployee(gendervarchar2(1),employee_idnumber);Tablecreated.Elapsed:00:00:00.05scott@ORCLPDB012023-04-0222:45:05>insertintoemployeevalues('F','99......
  • ORACLE PL/SQL 程序包的创建与应用
    原文地址:https://www.cnblogs.com/huyong/archive/2011/05/26/2057973.html本篇主要内容如下:第七章  程序包的创建和应用7.1  程序包简介7.2  程序包的定义7.3  包的开发步骤7.4  包定义的说明7.5  子程序重载7.6  加密实用程序7.7  删除包7.8  包的......
  • ORACLE之PACKAGE-包、存储过程、函数
    原文地址:https://www.cnblogs.com/hoaprox/p/5316444.html1,简单的包。创建包规范:createorreplacepackagepack_test1is--定义过程1procedurep_test1(p_1invarchar2);--定义函数1functionf_test1(p_1invarchar2)returnvarchar2;endpack_test1;......
  • 【测试】主流数据库存储过程编写样例(Oracle、MySQL、SQL Server)
    这个...做测试其实有时候还是需要先弄点数据才好针对某些功能进行测试的(相信做过开发的都应该深有体会)。一般像我这种老油条都推荐使用存储过程来做的初始化数据,一来脚本不会骗人,二来可以通过另一种方式验证逻辑关系。下面将整理了三个主流数据库(Oracle、MySQL和SQLServer)的“单表......
  • oracle存储过程调试无法进入,oracle存储过程无法调试
    问题:使用pl/sqldeveloper调试oracle 存储过程。在存储过程上点右键,选调试(test),然后按f9(debug)。这是正常的话,那些run、stepinto等按钮就可以点了,或者点run到断点,或者点stepinto做单步跟踪。但是在一个oraclerac双机环境中调试一个存储过程,点f9后有时能继续run或者stepint......
  • 在docker中配置Oracle11g
    在docker中配置Oracle11gdocker镜像拉取及相关配置1.在docker打开的情况下,使用下方命令拉去镜像,大概需要下载3个G的image文件dockerpullregistry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g2.启动Oracle镜像并为镜像新建容器,注意此处的oracle11g即为容器名,可以自主设置......
  • Oracle 执行Update 或 select for update 是卡着
    原因和解决方法这种只有update无法执行其他语句可以执行的其实是因为记录锁导致的,在oracle中,执行了update或者insert语句后,都会要求commit,如果不commit却强制关闭连接,oracle就会将这条提交的记录锁住。通过执行下列语句查询当前卡着的会话SELECTs.sid,s.serial#FROMv$l......
  • Oracle SQL语句执行步骤
    OracleSQL语句执行步骤Oracle中SQL语句执行过程中,Oracle内部解析原理如下:1、当一用户第一次提交一个SQL表达式时,Oracle会将这SQL进行Hardparse,这过程有点像程序编译,检查语法、表名、字段名等相关信息(如下图),这过程会花比较长的时间,因为它要分析语句的语法与语义。然后获得......
  • Oracle Docker安装及连接
    OracleDocker安装及连接拉取镜像运行镜像进入容器修改oracle配置修改root密码passwd切换oracle用户suoracle匿名登录oraclesqlplus/nologdba身份登录conn/assysdba修改用户system、sys用户的密码alterusersystemidentifiedbysystem;alterus......