单实例 Oracle 11G 升级到 ORACLE 12C

单实例 Oracle 11G 升级到 ORACLE 12C

编码文章call10242025-01-17 10:53:2516A+A-

介绍

本文介绍将单实例数据库从11.2.0.4 直接升级到12.2.0.1,在升级之前最好将数据库做一次完全备份(RMAN),以备不测!升级的过程和单独安装Oracle 12C 很像,先安装数据库软件,然后使用dbua对数据库升级.


升级前

升级后

系统版本/IP

Oracle linux 6.8/192.168.5.12

Oracle linux 6.8/192.168.5.12

数据库版本

11.2.0.4

12.2.0.1

ORACLE_BASE

/u01/app/oracle

/u01/app/oracle

ORACLE_HOME

$ORACLE_BASE/product/11.2.0/dbhome_1

$ORACLE_BASE/product/12.2.0/dbhome_1

ORACLE_SID

testdb

testdb

检查原数据库版本信息

使用sysr用户登录数据库:

SQL> select * from product_component_version;

SQL> SELECT COMP_NAME, VERSION, STATUS FROM DBA_REGISTRY;

检查操作系统

过程和单独安装数据库基本一样。

1.检查相关rpm包有没有安装(后面也可以补)

2.检查相关用户和目录是否创建

3.检查系统参数是否都设置了(后面也可以补)

4.不需要提前修改ORALE_HOME,安装完成后再修改也可以。

开始安装

将12c的数据库软件包
linuxx64_12201_database.zip上传到服务器上.使用Oracle解压,然后执行runInstaller.

[oracle@db01 ~]$ ll

total 3372756

-rwxrwxrwx 1 root root 3453696911 Aug 21 2019 linuxx64_12201_database.zip

[oracle@db01 ~]$ unzip linuxx64_12201_database.zip

[oracle@db01 database]$ ./runInstaller

选择升级一个存在的数据库,会先安装数据库软件,然后自动弹出窗口,升级数据库:(有点类似选择仅安装软件,然后手动使用dbua)

选择企业版:

由于还没有改变环境变量,这里需要手动设置12C的$ORACLE_HOME

用户组的选择,默认即可:

安装需求检查,如果有报错提示,按照提示解决:

点击fix & check Again,执行弹框的脚本:

安装的summary:

开始安装12C数据库软件:

使用root执行弹出窗口的脚本:

[root@db01 ~]# cd /u01/app/oracle/product/12.2.0/dbhome_1/

[root@db01 dbhome_1]# ./root.sh

执行完成后点击ok!

过一会直接弹出升级数据库界面,输入拥有sysdba权限的Oracle数据库用户和密码:我输入的是sys/oracle

检查升级相关的需求,可以浏览一下,有些可以直接忽略:

我这里勾选了在升级过程中将表空间设置为只读:

前面提到过,手动做一次数据库全备,这里选择我拥有一个备份:

检查到当前有一个监听,勾选后,监听也会跟着升级;不够选,也可以后面重新生成!

不安装EM:

安装Summary:

开始升级数据库,升级的过程时间较长,升级过程中可以看查看数据库的警告日志,和dbua日志:

过程中会有一个关于catalog的报错,可以忽略:

在升级的过程中,查看数据库警告日志和dbua日志可以发现,会经常的启停数据库。

数据库升级完成后,可以看到一个升级结果.,然后点击close!

返回到了最外面的升级程序,也点击close.

至此,单实例11.2.0.4数据库升级为12.2.0.1数据库,升级完成!

后续操作

1.修改oracle用户的环境变量

将$ORACLE_HOME指定新的位置

export ORACLE_HOME=$ORACLE_BASE/product/12.2.0/dbhome_1=

2.查看监听状态

[oracle@db01 ~]$ lsnrctl status

可以看到,监听的版本:LSNRCTL for Linux: Version 12.2.0.1.0

3.查看数据库版本和组件信息

用sys用户登录数据库:

SQL> select * from v$version;

SQL> select * from product_component_version;

SQL> SELECT COMP_NAME, VERSION, STATUS FROM SYS.DBA_REGISTRY;

4.检查数据库无效对象

SQL> select count(*) from dba_objects where status!='VALID';

5.注意

单实例数据库升级后,默认是非cdb状态的

6.重启数据库

如果需要的话,可以重启一遍数据库!

点击这里复制本文地址 以上内容由文彬编程网整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!
qrcode

文彬编程网 © All Rights Reserved.  蜀ICP备2024111239号-4