系统情况介绍

正式环境:windows 2008 r2-32bit/ Oracle: Release 11.2.0.1.0

目标环境:windows 2012 Standard-64bit / Oracle: Release 11.2.0.1.0

备份工具:EMC Avamar 7.5.1-RMAM全备

备份介绍

Avamar自动配置RMAN脚本,全备数据库,自动脚本日志内容如下(图形界面配置的,自动生成如下脚本,也可以手工写脚本备份):


1> RMAN> @@ORCL-24081.tmp
2> connect target *;
3> **文件结尾**
4> run {
5> configure controlfile autobackup on;
6> set controlfile autobackup format for device type sbt to 'CONTROLFILE.ORCL.%F';
7> allocate channel c0 type sbt PARMS="SBT_LIBRARY=C:\PROGRA~1\avs\bin\LIBOBK~1.DLL" format '%d_%U';
8> send channel 'c0' '"--libport=55154" "--force-expires" "--ctlusessl=false" "--cacheprefix=ORCL_c0" "--sysdir=C:\Program Files\avs\etc" "--bindir=C:\Program Files\avs\bin" "--vardir=C:\Program Files\avs\var\clientlogs" "--logfile=C:\Program Files\avs\var\clientlogs\yongyouLV0-yongyouLV0-1553436000010-3002-OracleORCL-avtar0.log" "--ctlcallport=55152"';
9> backup filesperset = 1 incremental level = 0 database plus archivelog delete input;
10> }
11>

还原过程

采用了Avamar恢复数据库的方式,实际上也是RMAN脚本,按照要求使用dbca命令建立好相同实例名称等,并备份相关控制文件(此步骤在Linux上可以手工建立)开始还原。其中需要注意的问题包含了恢复段的SCN号。开始没注意,导致完报错如下:

归档日志文件名=E:\APP\ADMINISTRATOR\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2019_03_21\O1_MF_1_29360_G97XBTPZ_.ARC 线程=1 序列=29360
通道 default: 正在删除归档日志
归档日志文件名=E:\APP\ADMINISTRATOR\FLASH_RECOVERY_AREA\ORCL\ARCHIVELOG\2019_03_21\O1_MF_1_29360_G97XBTPZ_.ARC RECID=8674 STAMP=1003498474
无法找到归档日志
归档日志线程=1 序列=29361
释放的通道: c0
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: recover 命令 (在 03/21/2019 13:34:38 上) 失败
RMAN-06054: 介质恢复正在请求未知的线程 1 序列 29361 的归档日志以及起始 SCN 983751610

再次使用SCN号参数恢复后,Avamar中显示恢复正常,但使用rman target / nocatalog 访问恢复后的数据库时,突然发现数据库无法启动,报错如下:


RMAN-00571: ====================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ========
RMAN-00571: ====================================================
RMAN-00554: 内部恢复管理器程序包初始化失败
RMAN-04005: 目标数据库中存在错误:
ORA-12432: LBAC 错误: zllesesinit:OCIStmtExecute

使用 sqlplus / as sysdba可以登陆数据库,但无法执行SQL语句,报错如下:

ORA-01012: not logged on

问题解决过程

在网上找了下相同情况的问题,其中在oracle官网找到了类似问题,如下图:

同时其他网站上大部分给出的解决方式为:

--Oracle给出的解决方案
--To solve this situation the LBAC option has to be disabled:
Step 1
cd $ORACLE_HOME/rdbms/lib
make -f ins_rdbms.mk lbac_off ioracle -- Author : Robinson Cheng
-- Blog : http://blog.csdn.net/robinson_0612
-- DB Forum : http://bbs.dbsupport.cn Step 2
$ sqlplus "/ as sysdba"
SQL> startup migrate
SQL> @?/rdbms/admin/catnools.sql
SQL> shutdown immediate
SQL> startup
SQL> select * from v$version where rownum<2;

但由于此次的环境为windows,尝试了使用step2的方式还是不行,又在网上找了下,发现别人的一片文章,链接如下:Fix ORA-12432: LBAC error: zllesesinit:OCIStmtExecute when you cannot logon - General Database Discussions。其中根据作者所述:

给了我解决思路。于是我采用此方式。sqlplus / as sysdba后先abort数据库,在尝试使用Step2的步骤

SQL>shutdown abort
SQL> startup migrate

此时数据库竟然起来了,继续执行Step2的步骤

SQL> @?/rdbms/admin/catnools.sql

发生报错ORA-06553: PLS-801: 内部错误 [56327]。尝试解决如下:

SQL>shutdown abort
SQL> startup upgrade
SQL> @?/rdbms/admin/utlirp
SQL> shutdown immediate

此时,又发生了报错ORA-12432: LBAC 错误: zllesesinit:OCIStmtExecute。继续尝试执行:

SQL>shutdown abort
SQL> startup upgrade
SQL> @?/rdbms/admin/utlrp

此后在此步骤一直卡住不动了,尝试开启了新的窗口,重新执行:

SQL> shutdown abort
SQL> startup migrate
SQL> @?/rdbms/admin/catnools.sql

此时数据库竟然没报错,再次使用以下命令后,数据库正常启动。

SQL> shutdown immediate
SQL> startup
SQL> select * from v$version where rownum<2;

问题总结

实际上本次迁移主要遇到的问题是:

  • ORA-01012: not logged on
  • ORA-12432: LBAC 错误: zllesesinit:OCIStmtExecute

    但是在处理这两个问题时发生了ORA-06553: PLS-801: 内部错误 [56327]的报错。在解决此报错时,没有办法按照正常的流程执行完所有的SQL只能分次多次执行。但最终来看运气还是比较好,妥善的解决了两个报错。最终数据库正常加载启动。

Oracle单机Rman笔记[6]---记一次oracle脱机异地还原的更多相关文章

  1. Oracle单机Rman笔记[5]---脱机异地还原

    脱机异地还原(安装一个原环境相同的linux,并安装数据库,注意不要配置安装实例) .检查/home/oracle下的.bashrc .bash_profile内容是否与原环境一致(具体看情况而定), ...

  2. Oracle单机Rman笔记[1]---环境准备

    A.-----安装程序准备---- 1.拷贝oracle安装包到一个目录下 2.检查并修改hostname /etc/sysconfig/network中的hostname要与/etc/hosts中的 ...

  3. Oracle单机Rman笔记[4]---RMAN联机备份

    备注:RMAN备份(仅支持基于spfile的备份,不支持基于init.ora配置的备份) 练习:开启ARCHIVELOG模式 \为归档的重做日志被指FRA和单独的归档日志目标 SQL>show ...

  4. Oracle单机Rman笔记[3]---RMAN脱机备份及命令基础介绍

    A.NOARCHIVELOG模式下的物理备份 1.完全关闭数据库 2.备份所有的数据库文件.控制文件.联机重做日志 3.重新启动数据库 B.RMAN的体系结构概述 重新构建控制文件: 将控制文件备份为 ...

  5. Oracle单机Rman笔记[2]---RMAN基础介绍

    A.DBA对于备份恢复的问题: 1.在数据库发生故障时,丢失多少数据是可承受的? 2.恢复数据库时,能够忍受的最长时间多少? 3.为了确保您的数据能够被恢复,愿意投入多少成本? 4.备份期间可以关闭系 ...

  6. Oracle单机Rman笔记[0]---环境准备

    A. 安装操作系统rhel6.6,关闭防火墙,修改网卡配置IP(略)PS:1.默认分区选项(第二项,默认为LVM),然后进行调整2.安装类型选择“桌面”3.安装后 分配IP.调整防火墙.测试SSH B ...

  7. ORACLE的RMAN

    1.什么是RMAN? RMAN可以用来备份和还原数据库文件.归档日志和控制文件.它也可以用来执行完全或不完全的数据库恢复. 注意:RMAN不能用于备份初始化参数文件和口令文件. RMAN启动数据库上的 ...

  8. oracle数据库rman备份计划及恢复

    1.rman完全恢复的前提条件:历史的datafile,controlfile和spfile备份,加上完整的archivelog和完好的redolog. 2.rman备份脚本: a.RMAN 0级备份 ...

  9. EntityFramework CodeFirst SQLServer转Oracle踩坑笔记

    接着在Oracle中使用Entity Framework 6 CodeFirst这篇博文,正在将项目从SQLServer 2012转至Oracle 11g,目前为止遇到的问题在此记录下. SQL Se ...

随机推荐

  1. 20175208 《Java程序设计》第八周学习总结

    20175208 2018-2019-3<Java程序设计>第八周学习总结 一.教材学习内容总结: 1.泛型: 泛型的主要目的是可以建立具有类型安全的集合框架(如链表.散列映射等数据结构) ...

  2. SQL Server实现远程访问

    1.打开SQL Server 配置管理器(SQL Server Configuration Manager) 2.启用SQL Server网络配置的TCP/IP:选中左侧的「SQL Server网络配 ...

  3. 关于 IIS 的 Management Service Delegation 配置 备份

    在MSDN没找到关于使用APPCMD备份IIS的"Management Service Delegation"模块配置命令. 到IIS的配置文件存放目录下,几番搜索,查到%wind ...

  4. Javascript在使用import 与export 区别及使用

    一.import与export的用法 1.import的几种用法 import defautName from 'modules.js'; import { export } from 'module ...

  5. 初试fiddler

    1.tools->Options->HTTPS勾:Decrypt HTTPS traffic //勾:Ignore server certificate errors(unsafe) // ...

  6. %zsy %lqs 随感

    今天是cj的大毒瘤zsy(对对,您说的都对,题目不难的啦,是我太菜啦)出题. 我校选手lqs仍然坚持高水平的发挥,wzy神犇却不在状态. 面对T1sb题(其实干了2h)和T3的原题(我&lqs ...

  7. Vue 组件&组件之间的通信 之 子组件向父组件传值

    子组件向父组件传值:子组件通过$.emit()方法以事件形式向父组件发送消息传值: 使用步骤: 定义组件:现有自定义组件com-a.com-b,com-a是com-b的父组件: 准备获取数据:父组件c ...

  8. xftp5和xshell的使用

    目的:实现windows和linux系统之间文件的传输 步骤:1)下载xshell5 百度搜索即可,直接下载安装 2)xshell5下载完成后与虚拟机链接成功 3)下载xftp5点击 然后跟据官方的指 ...

  9. PO、POJO、BO、DTO、VO之间的区别(转)

    PO:persistent object持久对象 1 .有时也被称为Data对象,对应数据库中的entity,可以简单认为一个PO对应数据库中的一条记录. 2 .在hibernate持久化框架中与in ...

  10. ValueObject

    ValueObject When programming, I often find it's useful to represent things as a compound混合物. A 2D co ...