Oracle 12C打补丁的简单尝试(r10笔记第55天)
最近在服务器盘点的时候,发现测试环境还是值得整合一下,因为服务器资源老旧,整体配置不高,服务器资源使用率不高,业务要求不高,多个实例分散在多台服务器上,要考虑灾备,要么是每天全库导出异地备份要么是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 Hom
e.
从以上的信息可以看出,这个模拟测试的环境,数据库软件是裸奔状态,没有任何的补丁。来到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查看就有了变化。
打补丁需要评估风险,胆大心细不为过。
- 图解“管道过滤器模式”应用实例:SOD框架的命令执行管道
- No.013 Roman to Integer
- OData – the best way to REST–实例讲解ASP.NET WebAPI OData (V4) Service & Client
- Java实现的手工做乘法方法,给出二个字符串数字,返回相乘结果
- No.012 Integer to Roman
- 黑帽SEO剖析之手法篇
- IOS学习1——IOS应用程序的生命周期及基本架构
- 浅议“全局变量”、“多线程”和“编译器陷阱”
- Java实现的图片合并方法,支持水平和垂直合并
- OC学习15——文件I/O体系
- 用惯了ORM,居然不会写分页SQL了
- OC学习14——谓词
- 如何在32位系统中使用ROP+Return-to-dl来绕过ASLR+DEP
- 如何使用Twitter构建C;C服务器
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法