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

时间:2024-01-26 05:48:21 

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


sys@EPAY>select database_role from v$database;
DATABASE_ROLE
----------------
PRIMARY
sys@EPAY>show parameter log_archive_dest_3
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
log_archive_dest_3                   string      SERVICE=sta ASYNC VALID_FOR=(O
                                                 NLINE_LOGFILES,PRIMARY_ROLE) D
                                                 B_UNIQUE_NAME=epaybk
log_archive_dest_30                  string
log_archive_dest_31                  string
sys@EPAY>alter system set log_archive_dest_state_3=defer scope=both;
System altered.


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

3. 在Primary上打补丁
3.1 关闭数据库实例,listener,ASM实例等
3.2 查看opatch的版本,如果不够,就去下载最新的版本
3.3 在Primary的Oracle软件上打补丁
3.4 为Primary数据库本身打补丁


cd $ORACLE_HOME/rdbms/admin
sqlplus /nolog
SQL> CONNECT / AS SYSDBA
SQL> STARTUP
SQL> @catbundle.sql psu apply
SQL> QUIT


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


sys@EPAY>alter system register;
System altered.


4.3 重新启动日志传输服务


sys@EPAY>alter system set log_archive_dest_state_3=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-16191
------------------------------------------------------------


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


sys@EPAY>alter database recover managed standby database disconnect from session;
Database altered.


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


sys@EPAY>select max(sequence#) from v$archived_log;
MAX(SEQUENCE#)
--------------
           159


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


sys@EPAY>select sequence#, applied from v$archived_log;


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


alter database recover managed standby database disconnect from session
Attempt to start background Managed Standby Recovery process (epay)
Wed Jul 10 06:03:48 2013
MRP0 started with pid=29, OS id=15030
MRP0: Background Managed Standby Recovery process started (epay)
 started logmerger process
Wed Jul 10 06:03:53 2013
Managed Standby Recovery not using Real Time Apply
Wed Jul 10 06:04:01 2013
Parallel Media Recovery started with 32 slaves
Waiting for all non-current ORLs to be archived...
All non-current ORLs have been archived.
Wed Jul 10 06:04:01 2013
Completed: alter database recover managed standby database disconnect from session
Media Recovery Log /data/oradata/epay/archivelog/1_157_814716635.dbf
Media Recovery Log /data/oradata/epay/archivelog/1_158_814716635.dbf
Media Recovery Log /data/oradata/epay/archivelog/1_159_814716635.dbf
Media Recovery Waiting for thread 1 sequence 160 (in transit)


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

标签:Data,Guard,CPU/PSU补丁,安装
0
投稿

猜你喜欢

  • Python+OCR实现文档解析的示例代码

    2023-11-22 02:34:19
  • 只需要这一行代码就能让python计算速度提高十倍

    2023-01-30 15:16:02
  • Python中模拟enum枚举类型的5种方法分享

    2022-05-04 01:00:10
  • Python列表删除重复元素与图像相似度判断及删除实例代码

    2021-02-21 05:28:58
  • python中os包的用法

    2021-07-11 07:24:02
  • MySQL 原理与优化之Update 优化

    2024-01-17 03:03:35
  • Python Numpy之linspace用法说明

    2021-10-17 10:49:55
  • Python使用字典的嵌套功能详解

    2021-03-19 01:20:02
  • 导致sql执行速度慢的几种情况盘点(生产环境踩过的坑)

    2024-01-17 17:07:21
  • python爬取哈尔滨天气信息

    2023-12-10 22:28:05
  • Mysql InnoDB的锁定机制实例详解

    2024-01-23 17:32:27
  • 简单获取键盘的KeyCode

    2008-04-18 12:37:00
  • numpy的squeeze函数使用方法

    2022-04-15 10:02:07
  • 记一次Django响应超慢的解决过程

    2021-11-23 13:35:57
  • 新版php study根目录下文件夹无法显示的图文解决方法

    2023-11-15 00:44:29
  • python json load json 数据后出现乱序的解决方案

    2021-01-25 02:49:02
  • 详解python的异常捕获

    2023-05-27 11:24:03
  • 详解python第三方库的安装、PyInstaller库、random库

    2023-03-13 06:57:46
  • SQL Server 分页查询存储过程代码

    2024-01-21 04:53:40
  • Golang学习之无类型常量详解

    2024-02-14 13:41:09
  • asp之家 网络编程 m.aspxhome.com