数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

[Oracle] Data Guard CPU/PSU补丁安装详细教程


发布日期:2018年10月20日
 
[Oracle] Data Guard CPU/PSU补丁安装详细教程
以下是对Data Guard CPU/PSU补丁安装的方法进行了详细的分析介绍需要的朋友可以参考下

非Data Guard的补丁安装教程可参考《[Oracle] CPU/PSU补丁安装详细教程》Data Guard需要Primary和Standby同时打上补丁所以步骤更复杂一些其主要步骤如下
在Primary停止日志传输服务
关闭Standby数据库在Standby的软件上打补丁(注意不需要为Standby数据库打补丁)启动standby为mount状态不启用managed recovery
关闭Primary在Primary的软件和数据库本身都打上补丁
启动Primary数据库重新开启日志传输服务
在Standby启动Redo Apply这样Primary上补丁脚本就会自动同步至Standby
检查Primary和Standby是否都已安装补丁
下面是一个具体例子
在Primary停止日志传输服务

复制代码 代码如下:
sys@EPAY>select database_role from v$database;
DATABASE_ROLE

PRIMARY
sys@EPAY>show parameter log_archive_dest_
NAME TYPE VALUE

log_archive_dest_ string SERVICE=sta ASYNC VALID_FOR=(O
NLINE_LOGFILESPRIMARY_ROLE) D
B_UNIQUE_NAME=epaybk
log_archive_dest_ string
log_archive_dest_ string
sys@EPAY>alter system set log_archive_dest_state_=defer scope=both;
System altered


在Standby的Oracle软件打上补丁
关闭数据库实例listenerASM实例等
查看opatch的版本如果不够就去下载最新的版本
在Standby的Oracle软件上打补丁
启动Standby到mount状态启动listener
(注意Standby不需要对数据库本身打补丁)

在Primary上打补丁
关闭数据库实例listenerASM实例等
查看opatch的版本如果不够就去下载最新的版本
在Primary的Oracle软件上打补丁
为Primary数据库本身打补丁

复制代码 代码如下:
cd $ORACLE_HOME/rdbms/admin
sqlplus /nolog
SQL> CONNECT / AS SYSDBA
SQL> STARTUP
SQL> @catbundlesql psu apply
SQL> QUIT


在Primary启动日志传输服务
启动Primary listener数据库实例等
强制注册services到listener

复制代码 代码如下:
sys@EPAY>alter system register;
System altered


重新启动日志传输服务

复制代码 代码如下:
sys@EPAY>alter system set log_archive_dest_state_=enable scope=both;
System altered


注意启动日志传输在alert里有可能出现如下错误

复制代码 代码如下:

Check that the primary and standby are using a password file
and remote_login_passwordfile is set to SHARED or EXCLUSIVE
and that the SYS password is same in the password files
returning error ORA


根据错误信息的提示应该是主库在做CPU补丁的时候把sys密码修改了用主库的密码文件替换备库的密码文件即可解决该错误
Standby启动Redo Apply
open Standby 数据库
启用Redo Apply

复制代码 代码如下:
sys@EPAY>alter database recover managed standby database disconnect from session;
Database altered


验证Primary和Standby是否同步
在primary端查询当前最大的归档日志序号

复制代码 代码如下:
sys@EPAY>select max(sequence#) from v$archived_log;
MAX(SEQUENCE#)


在standby端查询已传过来的归档日志

复制代码 代码如下:
sys@EPAY>select sequence# applied from v$archived_log;


从alertlog可用看出同步了个日志文件(即把在primary打的补丁同步到了standby)

复制代码 代码如下:
alter database recover managed standby database disconnect from session
Attempt to start background Managed Standby Recovery process (epay)
Wed Jul ::
MRP started with pid= OS id=
MRP: Background Managed Standby Recovery process started (epay)
started logmerger process
Wed Jul ::
Managed Standby Recovery not using Real Time Apply
Wed Jul ::
Parallel Media Recovery started with slaves
Waiting for all noncurrent ORLs to be archived
All noncurrent ORLs have been archived
Wed Jul ::
Completed: alter database recover managed standby database disconnect from session
Media Recovery Log /data/oradata/epay/archivelog/__dbf
Media Recovery Log /data/oradata/epay/archivelog/__dbf
Media Recovery Log /data/oradata/epay/archivelog/__dbf
Media Recovery Waiting for thread sequence (in transit)


后期检查补丁是否安装成功
在primary standby分别指向opatch lsinventory
在数据库里检查补丁是否安装成功

               

上一篇:Oracle Linux 6桥接网卡

下一篇:如何杀死oracle死锁进程