Oracle 12C打补丁的简单尝试
最近在服务器盘点的时候,发现测试环境还是值得整合一下,因为服务器资源老旧,整体配置不高,服务器资源使用率不高,业务要求不高,多个实例分散在多台服务器上,要考虑灾备,要么是每天全库导出异地备份要么是Data Guard,其实还是蛮适合使用容器的方式来管理的。
之前整合过几个测试环境,是整合到11g中,发现有几个钉子户实在没法迁移了,因为几个数据库中的用户名有重复的,同义词也有重复的,处理起来就很纠结。所以最后就暂且放下,现在12c也有些年头了,咱也得充分利用它的亮点特性不是。
测试整合的想法要付诸行动,还是要有一些测试演练的过程来印证 ,尽可能把影响降到最低,提高迁移的效率,而且也要与时俱进,那就是PSU了。
我的想法是打上最新的补丁,然后就可以在很长的一段时间内不用考虑版本更新的问题了,而且补丁里面修复了大量的bug,也不用重新淌一遍哪些bug。在迁移的时候直接克隆安装,也算是一步到位。
简单查看当前的版本情况。
[Oracle@odb12c OPatch]$ ./opatch lsinventory
Oracle Interim Patch Installer version 12.1.0.1.3
Copyright (c) 2016, Oracle Corporation. All rights reserved.
Oracle Home : /U01/app/oracle/product/12c/db_1
Central Inventory : /U01/app/oraInventory
from : /U01/app/oracle/product/12c/db_1/oraInst.loc
OPatch version : 12.1.0.1.3
OUI version : 12.1.0.2.0
。。
Oracle Database 12c 12.1.0.2.0
There are no Interim patches installed in this Oracle Home.
从以上的信息可以看出,这个模拟测试的环境,数据库软件是裸奔状态,没有任何的补丁。来到MOS上下载即可,快捷方式是图里显示的方式了。
搜索过滤后得到的结果很清晰,就两行记录,选择的是第一条。这个补丁是比较新的了。7月份的。
顺着链接进来,就是一个标准的下载界面,简单确认一下,就开始下载吧,这个补丁大概有200多M。下载的感觉就如同一个孩子目前和健康,但是还得给他打打疫苗。
下载花了些时间,打补丁的过程其实就很简单了,关键就是apply这一步了。
常规的步骤如下:
unzip p23054246_12102_.zip
cd 23054246
opatch apply
三个步骤下来,不出意外几分钟就可以顺利搞定。但是在我的这个场景中竟然还有问题。
这个错误让我有些奇怪,查了下资料,发现是OPatch的版本过低导致。
这个步骤可以参考MOS的文档说明
How To Download And Install The Latest OPatch(6880880) Version (Doc ID 274526.1)
所以需要下载一个新版本的OPatch,顺着链接里提供的方式去操作,就能够找到下面的连接了。下载相应的OPatch即可。
这个版本的更新是在8月份,绝对是跟得上时代了。
OPatch的处理可以查看readme.txt,步骤还是老三件。官方的说明如下:
(1) Please take a backup of ORACLE_HOME/OPatch into a dedicated backup
location.
(2) Please make sure no directory ORACLE_HOME/OPatch exist.
(3) Please unzip the OPatch downloaded zip into ORACLE_HOME directory.
操作起来就很简单了。备份,替换
[oracle@odb12c ~]$ cp -r /U01/app/oracle/product/12c/db_1/OPatch/ OPatch_bak
[oracle@odb12c ~]$ rm -rf /U01/app/oracle/product/12c/db_1/OPatch
[oracle@odb12c ~]$ mv OPatch /U01/app/oracle/product/12c/db_1
更新OPatch之后,查看的结果就有了变化。
[oracle@odb12c OPatch]$ ./opatch lsinventory
Oracle Interim Patch Installer version 12.2.0.1.7
Copyright (c) 2016, Oracle Corporation. All rights reserved.
Oracle Home : /U01/app/oracle/product/12c/db_1
Central Inventory : /U01/app/oraInventory
from : /U01/app/oracle/product/12c/db_1/oraInst.loc
OPatch version : 12.2.0.1.7
OUI version : 12.1.0.2.0
然后再次尝试apply的步骤,没想到还是有一个报错。
这个问题看起来有些奇怪,顺着报错来分析,其实就是监听没停掉,停掉监听之后,再次尝试apply操作。
屏幕不断地输出,最后提示一句 OPatch succeeded.
使用opatch lsinventory查看就有了变化。