【Oracle不停库迁移, 迁移完成无法启动】

MD@[Oracle不停库迁移, 迁移完成无法启动]

Oracle不停库迁移, 迁移完成无法启动

说明: 1. 在企业上云的大背景下, 自建数据库迁移到云服务器内, 场景较为常见。本文意在解决Oracle迁移到云服务器内,无法启动的问题。

  1. 用云厂商的迁移服务(如, 华为云SMS),迁移到云服务器上, 目的端会重启。

  2. 该文档可解决Oracle故障码: ORA-00214, ORA-00742, ORA-00312, ORA-01547, ORA-01152, ORA-01110, ORA-01194, ORA-00279, ORA-00289, ORA-00280, ORA-01507

1. 启动监听

(1) 检查监听器状态
[oracle@sjclinux ~]$ lsnrctl status
(2) 启动监听器
[oracle@sjclinux ~]$ lsnrctl start
(3) 停止监听器
[oracle@sjclinux ~]$ lsnrctl stop

2. 调整控制文件ctl一致 (ORA-00214)

ORA-00214: control file '/.../control02.ctl'version 906 inconsistent with file '/.../control01.ctl'
问题描述 :启动Oracle实例时显示错误, SQL> startup;
问题分析 :该故障码是说控制文件版本不一致。控制文件原理为维护数据库的当前物理状态,为二进制文件,数据库打开的时候控制文件一致变化。主要记录数据库名字、标示、当前日志SCN、表空间信息等。理论上3个控制文件应该一致。
解决办法 :备份control01.ctl,复制一个control02.ctl改名为control01.ctl,直接根据报错信息找文件位置即可。
脚本语句 :[oracle@sjclinux ~]$ cp /oracledata/fast_recovery_area/XXXXX/control02.ctl /oracledata/oradata/XXXXX/control01.ctl
尝试启动,sqlplus登录后, SQL> startup, 如果启动成功不用继续

3. 调整日志文件log一致 (ORA-00742) , 重置redolog

3.1 接上面的尝试启动, 如果出现以下报错:

ORA-00742: Log read detects lost write in thread 1 sequence 1202 block 137840

ORA-00312: online log 18 thread 1: '/u01/app/oracle/oradata/orcl/redo18.log'
问题分析 :迁移服务器,目的端会需要重新启动,若正好有业务在运行,相当于宕机。数据库本身应当支持这样的宕机恢复,不必担心。
解决办法 :尝试recover (可能会失败, 失败继续往下)
脚本语句

SQL> RECOVER DATABASE UNTIL CANCEL; //尝试recover

3.2 如果尝试启动, 出现以下报错

ORA-01547: 警告: RECOVER 成功但 OPEN RESETLOGS 将出现如下错误

ORA-01152: 文件 1 没有从过旧的备份中还原

ORA-01110: 数据文件 1: '/oracle/oradata/orcl/system01.dbf'
问题分析 :很明显控制文件中的scn没赶上数据文件和数据头文件中的变化 然后尝试不玩全恢复
解决办法 :尝试重置日志 (可能会失败, 失败继续往下)
脚本语句 :SQL> alter database open resetlogs; //一般情况下到这里就能启动
3.3 接上一步, 如果尝试启动, 又出现以下报错

SQL> alter database open resetlogs;

alter database open resetlogs

*

ERROR at line 1:

ORA-01194: file 1 needs more recovery to be consistent

ORA-01110: data file 1: '/u01/app/oracle/oradata/orcl/system01.dbf'
问题分析 :基本可以确定是日志的问题
脚本语句

SQL> recover database using backup controlfile until cancel;

ORA-00279: change 669109 generated at 09/12/2009 18:47:00 needed for thread 1

ORA-00289: suggestion :

/u01/app/oracle/flash_recovery_area/ORCL/archivelog/2009_09_13/o1_mf_1_10_%u_.ar

c

ORA-00280: change 669109 for thread 1 is in sequence #10

Specify log: {=suggested | filename | AUTO | CANCEL}
继续执行 :输入CANCEL

根据上面提示的内容,注意到 'change 669109 ' 和 'sequence #10',执行以下语句,可以查出redo logs ,注意要用sys:

SQL> conn sys/oracle as sysdba

Connected.

SQL> select v1.group#, member, sequence#, first_change# from v l o g v 1 , v log v1, v logv1,vlogfile v2 where v1.group# = v2.group#;
情况描述 :从结果里根据 sequence# 和 first_change# 找到了要用到的log file name:

/u01/app/oracle/oradata/orcl/redo03.log。在 Specify log: {=suggested | filename | AUTO | CANCEL} 下面输入:

/u01/app/oracle/oradata/orcl/redo03.log
弹出提示

Log applied.

Media recovery complete.
再重置logs

SQL> alter database open resetlogs;

Database altered.

看到Database altered, 说明基本解决。

4. 相关命令

bash 复制代码
4.1 sqlplus:用于登录sqlplus
[oracle@sjclinux ~]$ sqlplus sys/oracle as sysdba;

4.2.1 启动数据库
SQL> startup;

4.2.2 启动数据库, 并mount, 
解决: ORA-01507: database not mounted
SQL> startup mount;

4.3 关闭数据库
SQL> shutdown immediate;

4.4 强制关闭数据库
SQL> SHUTDOWN ABORT;

4.5 创建pfile
create pfile from spfile;

4.6 创建spfile
create spfile from pfile;

4.7 退出
SQL> exit;
相关推荐
月空MoonSky9 分钟前
Oracle中TRUNC()函数详解
数据库·sql·oracle
momo小菜pa9 分钟前
【MySQL 06】表的增删查改
数据库·mysql
向上的车轮1 小时前
Django学习笔记二:数据库操作详解
数据库·django
编程老船长1 小时前
第26章 Java操作Mongodb实现数据持久化
数据库·后端·mongodb
全栈师2 小时前
SQL Server中关于个性化需求批量删除表的做法
数据库·oracle
Data 3172 小时前
Hive数仓操作(十七)
大数据·数据库·数据仓库·hive·hadoop
BergerLee2 小时前
对不经常变动的数据集合添加Redis缓存
数据库·redis·缓存
gorgor在码农3 小时前
Mysql 索引底层数据结构和算法
数据结构·数据库·mysql
bug菌¹3 小时前
滚雪球学Oracle[6.2讲]:Data Guard与灾难恢复
数据库·oracle·data·灾难恢复·guard
一般路过糸.3 小时前
MySQL数据库——索引
数据库·mysql