데이터 베이스 MySQL 튜토리얼 【RAC】11gR2 rac 上滚动安装/回退补丁

【RAC】11gR2 rac 上滚动安装/回退补丁

Jun 07, 2016 pm 05:15 PM

在RAC环境上安装小补丁时,可以使用滚动安装的方式(Rolling)以提供无间断的业务应用!在安装补丁的时候,先停止一个数据库实例,

在RAC环境上安装小补丁时,可以使用滚动安装的方式(Rolling)以提供无间断的业务应用!在安装补丁的时候,先停止一个数据库实例,,在此节点安装补丁,然后启动这个实例,再停止另一个实例并安装这个补丁,这样能够保证一直有可用的数据库实例,业务能够无间断提供服务!
   使用滚动安装的前提是这个补丁是可以Rolling安装的,对于如何判断一个补丁是Rolling的,下面的文章中会提到。
一般来说,大体的Rolling安装的方式如下:
1. 下载补丁。
2. 打补丁之前,最好做一下数据库的备份。
3. 检查这次安装的补丁是否和以往的补丁冲突。
4. 如果有测试库,最好先在测试库测试一下这个补丁。
5. 务必仔细阅读补丁的Readme并按照其中的步骤来打补丁:
   1). 用Oracle用户将这个补丁上传到服务器上的一个目录.
   2). 解压这个文件:
   3). 停止节点1这个ORACLE_HOME下所有的数据库实例+ASM实例(如果有,11g rac 可以不用,10g需要);
   4). 在节点1打补丁:
        $cd $ORACLE_HOME/OPatch/9711859 (目录可以根据实际情况更改)
        $opatch apply
    5). 然后opatch会问您是否要打下一个节点2,这时候执行下面的操作:
    6). 启动节点1 的ORACLE_HOME下所有的数据库实例+ASM实例(如果有);
    7). 停止节点2这个ORACLE_HOME下所有的数据库实例+ASM实例(如果有);
    8). 在之前打补丁的那个提示符中,确认继续打下一个节点;
    9). 启动节点2 这个ORACLE_HOME下所有的数据库实例+ASM实例(如果有);
   10).如果有多个节点,依次执行。
一 下载 opatch 和补丁~!
a)检查 opatch 的版本
oracle@rac1:/home/oracle/software>opatch version  
Invoking OPatch 11.1.0.6.6
OPatch Version: 11.1.0.6.6
OPatch succeeded.
b)下载最新的版本
我的是以p9711859_112010_Linux-x86-64.zip 为例!
备份 老的opatch ,解压新的optach
oracle@rac1:/home/oracle/software>cd $ORACLE_HOME
oracle@rac1:/opt/rac/oracle/11.2.0/rac> tar zcvf OPatch_`date +%Y%m%d`.tar.gz OPatch
OPatch/
oracle@rac1:/home/oracle/software>unzip p6880880_112000_Linux-x86-64.zip -d $ORACLE_HOME
Archive:  p6880880_112000_Linux-x86-64.zip
replace /opt/rac/oracle/11.2.0/rac/OPatch/docs/Users_Guide.txt? [y]es, [n]o, [A]ll, [N]one, [r]ename: A
..........
 inflating: /opt/rac/oracle/11.2.0/rac/OPatch/crs/s_crsconfig_lib.pm
查看opatch 的版本!
oracle@rac1:/home/oracle/software>opatch version
OPatch Version: 11.2.0.3.0
OPatch succeeded.
oracle@rac1:/home/oracle/software>
c)下载要安装的补丁并且检查是否满足rolling apply
oracle@rac1:/home/oracle>opatch query -all /home/oracle/software/9711859 | grep rolling
Patch is a rolling patch: true
二 停止节点1 rac1 的监听
oracle@rac1:/home/oracle>srvctl stop listener -l LISTENER -n rac1
oracle@rac1:/home/oracle>
oracle@rac1:/home/oracle>srvctl status listener -l LISTENER
监听程序 LISTENER 已启用
监听程序 LISTENER 正在节点上运行: rac2
停止节点1 上的数据库实例 (对于10版本还要停止asm 实例)
oracle@rac1:/home/oracle>srvctl status instance -d rac -i rac1
实例 rac1 正在节点 rac1 上运行
oracle@rac1:/home/oracle>srvctl stop instance -d rac -i rac1
三 开始rolling方式应用补丁:
oracle@rac1:/home/oracle/software/9711859>opatch apply
Oracle 中间补丁程序安装程序版本 11.2.0.3.0
版权所有 (c) 2012, Oracle Corporation。保留所有权利。
Oracle Home       : /opt/rac/oracle/11.2.0/rac
Central Inventory : /opt/rac/oraInventory
   from           : /opt/rac/oracle/11.2.0/rac/oraInst.loc
OPatch version    : 11.2.0.3.0
OUI version       : 11.2.0.1.0
Log file location : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/9711859_Jun_25_2012_16_16_42/apply2012-06-25_16-16-42下午_1.log
Applying interim patch '9711859' to OH '/opt/rac/oracle/11.2.0/rac'
Verifying environment and performing prerequisite checks...
All checks passed.
提供电子邮件地址以用于接收有关安全问题的通知, 安装 Oracle Configuration Manager 并启动它。如果您使用 My Oracle
Support 电子邮件地址/用户名, 操作将更简单。
有关详细信息, 请访问 。
电子邮件地址/用户名: qilong.yangql@gmail.com
请提供 My Oracle Support 口令以通过 My Oracle Support 帐户接收安全更新。
口令口令 (可选):     
此节点是 Oracle Real Application Cluster 的一部分。
远程节点: 'rac2'
本地节点: 'rac1'
请关闭本地系统上在此 ORACLE_HOME 之外运行的 Oracle 实例。
(Oracle 主目录 = '/opt/rac/oracle/11.2.0/rac')

本地系统是否已准备打补丁? [y|n]y
User Responded with: Y
Backing up files...
正在为组件 oracle.rdbms, 11.2.0.1.0 打补丁...
Verifying the update...
本地系统已打补丁。您可以在本地系统上重新启动 Oracle 实例。
在滚动模式下打补丁。
接下来将为节点 'rac2' 打补丁。
请关闭 'rac2' 上在此 ORACLE_HOME 之外运行的 Oracle 实例。
(Oracle 主目录 = '/opt/rac/oracle/11.2.0/rac')

//在询问你是否在另外一个节点安装补丁的时候
四 在节点rac1上启动数据库和监听操作
oracle@rac1:/home/oracle/software/9711859>srvctl start instance  -d rac -i rac1 -o open             
oracle@rac1:/home/oracle/software/9711859>srvctl status instance  -d rac -i rac1           
实例 rac1 正在节点 rac1 上运行
oracle@rac1:/home/oracle/software/9711859>srvctl start listener -l LISTENER -n rac1
PRCC-1015 : LISTENER 已在 rac1 上运行五 关闭节点rac2 的监听和数据库实例操作
oracle@rac1:/home/oracle/software/9711859>srvctl stop listener -l LISTENER -n rac2
oracle@rac1:/home/oracle/software/9711859>srvctl stop instance  -d rac -i rac2
该节点是否已准备打补丁? [y|n]  y
User Responded with: Y
Updating nodes 'rac2'
   Apply-related files are:
     FP = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt"
     DP = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_dirs.txt"
     MP = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt"
     RC = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remote_cmds.txt"

Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt" with actual path.
Propagating files to remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_dirs.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_dirs.txt" with actual path.
Propagating directories to remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt" with actual path.
Running command on remote node 'rac2':
cd /opt/rac/oracle/11.2.0/rac/rdbms/lib; /usr/bin/make -f ins_rdbms.mk ioracle ORACLE_HOME=/opt/rac/oracle/11.2.0/rac || echo REMOTE_MAKE_FAILED::>&2
节点 'rac2' 已打补丁。您可以在该节点上重新启动 Oracle 实例。
远程节点上存在重链接。一定要检查节点 'rac2'  上的二进制文件的大小和时间戳。
已在远程节点上调用以下 make 命令:
'cd /opt/rac/oracle/11.2.0/rac/rdbms/lib; /usr/bin/make -f ins_rdbms.mk ioracle ORACLE_HOME=/opt/rac/oracle/11.2.0/rac
'
Patch 9711859 successfully applied
Log file location: /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/9711859_Jun_25_2012_16_16_42/apply2012-06-25_16-16-42下午_1.log
OPatch succeeded.
六 在两个节点分别执行下面的命令来确认补丁已经安装成功。
oracle@rac1:/home/oracle/software/9711859>opatch lsinventory
Oracle 中间补丁程序安装程序版本 11.2.0.3.0
版权所有 (c) 2012, Oracle Corporation。保留所有权利。
Oracle Home       : /opt/rac/oracle/11.2.0/rac
Central Inventory : /opt/rac/oraInventory
   from                : /opt/rac/oracle/11.2.0/rac/oraInst.loc
OPatch version    : 11.2.0.3.0
OUI version         : 11.2.0.1.0
Log file location   : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/opatch2012-06-25_16-36-30下午_1.log
Lsinventory Output file location : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/lsinv/lsinventory2012-06-25_16-36-30下午.txt
--------------------------------------------------------------------------------
已安装的顶级产品 (1):
Oracle Database 11g                                                  11.2.0.1.0
此 Oracle 主目录中已安装 1 个产品。
中间补丁程序 (1) :
Patch  9711859      : applied on Mon Jun 25 16:22:36 CST 2012
Unique Patch ID:  12670211
   Created on 9 Jun 2010, 10:13:45 hrs PST8PDT
   Bugs fixed:
     9711859
包含多个节点的 RAC 系统
  Local node = rac1
  Remote node = rac2
--------------------------------------------------------------------------------
OPatch succeeded.
同样在节点2上的确认 输出略!


回退补丁9711859的过程~
一  将节点1 的数据库实例关闭
  执行
  srvctl stop instance -d rac -i rac1
  srvctl stop listener -l LISTENER -n rac1
二 执行回退补丁:
oracle@rac1:/home/oracle/software/9711859>opatch rollback -id 9711859
Oracle 中间补丁程序安装程序版本 11.2.0.3.0
版权所有 (c) 2012, Oracle Corporation。保留所有权利。
Oracle Home       : /opt/rac/oracle/11.2.0/rac
Central Inventory : /opt/rac/oraInventory
   from           : /opt/rac/oracle/11.2.0/rac/oraInst.loc
OPatch version    : 11.2.0.3.0
OUI version       : 11.2.0.1.0
Log file location : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/9711859_Jun_25_2012_17_30_32/rollback2012-06-25_17-30-32下午_1.log
RollbackSession 从 OH '/opt/rac/oracle/11.2.0/rac' 回退中间补丁程序 '9711859'
此节点是 Oracle Real Application Cluster 的一部分。
远程节点: 'rac2'
本地节点: 'rac1'
请关闭所有节点上在此 ORACLE_HOME 之外运行的 Oracle 实例。
(Oracle 主目录 = '/opt/rac/oracle/11.2.0/rac')
所有节点是否都已准备打补丁? [y|n]
y
User Responded with: Y
正在为组件 oracle.rdbms, 11.2.0.1.0 打补丁...
RollbackSession 从产品清单中删除中间补丁程序 '9711859'
在滚动模式下打补丁。
接下来将为节点 'rac2' 打补丁。
请关闭 'rac2' 上在此 ORACLE_HOME 之外运行的 Oracle 实例。
(Oracle 主目录 = '/opt/rac/oracle/11.2.0/rac')
三 在节点rac1上启动数据库和监听操作
oracle@rac1:/home/oracle/software/9711859>srvctl start instance  -d rac -i rac1 -o open             
oracle@rac1:/home/oracle/software/9711859>srvctl status instance  -d rac -i rac1           
实例 rac1 正在节点 rac1 上运行
oracle@rac1:/home/oracle/software/9711859>srvctl start listener -l LISTENER -n rac1
PRCC-1015 : LISTENER 已在 rac1 上运行 四 关闭节点rac2 的监听和数据库实例操作
oracle@rac1:/home/oracle/software/9711859>srvctl stop listener -l LISTENER -n rac2
oracle@rac1:/home/oracle/software/9711859>srvctl stop instance  -d rac -i rac2
五 选择在节点rac2上卸载补丁!
该节点是否已准备打补丁? [y|n]
y
User Responded with: Y
Updating nodes 'rac2'
   Rollback-related files are:
     FR = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_files.txt"
     DR = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_dirs.txt"
     FP = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt"
     MP = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt"
     RC = "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remote_cmds.txt"

Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_files.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_files.txt" with actual path.
Removing files on remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_dirs.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/remove_dirs.txt" with actual path.
Removing directories on remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_files.txt" with actual path.
Propagating files to remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_dirs.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/copy_dirs.txt" with actual path.
Propagating directories to remote nodes...
Instantiating the file "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt.instantiated" by replacing $ORACLE_HOME in "/opt/rac/oracle/11.2.0/rac/.patch_storage/9711859_Jun_9_2010_10_13_45/rac/make_cmds.txt" with actual path.
Running command on remote node 'rac2':
cd /opt/rac/oracle/11.2.0/rac/rdbms/lib; /usr/bin/make -f ins_rdbms.mk ioracle ORACLE_HOME=/opt/rac/oracle/11.2.0/rac || echo REMOTE_MAKE_FAILED::>&2


节点 'rac2' 已打补丁。您可以在该节点上重新启动 Oracle 实例。
远程节点上存在重链接。一定要检查节点 'rac2'  上的二进制文件的大小和时间戳。
已在远程节点上调用以下 make 命令:
'cd /opt/rac/oracle/11.2.0/rac/rdbms/lib; /usr/bin/make -f ins_rdbms.mk ioracle ORACLE_HOME=/opt/rac/oracle/11.2.0/rac'
Log file location: /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/9711859_Jun_25_2012_17_30_32/rollback2012-06-25_17-30-32下午_1.log
OPatch succeeded.
六 在两个节点检查是否回滚成功!
oracle@rac1:/home/oracle/software/9711859>opatch lsinventory       
Oracle 中间补丁程序安装程序版本 11.2.0.3.0
版权所有 (c) 2012, Oracle Corporation。保留所有权利。
Oracle Home       : /opt/rac/oracle/11.2.0/rac
Central Inventory : /opt/rac/oraInventory
   from           : /opt/rac/oracle/11.2.0/rac/oraInst.loc
OPatch version    : 11.2.0.3.0
OUI version       : 11.2.0.1.0
Log file location : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/opatch2012-06-25_17-41-29下午_1.log
Lsinventory Output file location : /opt/rac/oracle/11.2.0/rac/cfgtoollogs/opatch/lsinv/lsinventory2012-06-25_17-41-29下午.txt
-------------------------------------------------------------------------------
已安装的顶级产品 (1):
Oracle Database 11g                                                  11.2.0.1.0
此 Oracle 主目录中已安装 1 个产品。
此 Oracle 主目录中未安装任何中间补丁程序。
包含多个节点的 RAC 系统
  Local node = rac1
  Remote node = rac2
--------------------------------------------------------------------------------
OPatch succeeded.

linux

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

이 기사는 Docker에서 MySQL 메모리 사용을 최적화합니다. 모니터링 기술 (Docker Stats, Performance Schema, 외부 도구) 및 구성 전략에 대해 설명합니다. 여기에는 Docker 메모리 제한, 스와핑 및 CGroups와 함께 포함됩니다

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

이 기사에서는 MySQL의 "공유 라이브러리를 열 수 없음"오류를 다룹니다. 이 문제는 MySQL이 필요한 공유 라이브러리 (.so/.dll 파일)를 찾을 수 없음에서 비롯됩니다. 솔루션은 시스템 패키지 M을 통한 라이브러리 설치 확인과 관련이 있습니다.

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

이 기사는 Linux에 MySQL을 직접 설치하는 것과 Phpmyadmin이없는 Podman 컨테이너 사용을 비교합니다. 각 방법에 대한 설치 단계에 대해 자세히 설명하면서 Podman의 격리, 이식성 및 재현성의 장점을 강조하지만 또한

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

이 기사는 자체 포함 된 서버리스 관계형 데이터베이스 인 SQLITE에 대한 포괄적 인 개요를 제공합니다. SQLITE의 장점 (단순성, 이식성, 사용 용이성) 및 단점 (동시성 제한, 확장 성 문제)에 대해 자세히 설명합니다. 기음

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

이 안내서는 Homebrew를 사용하여 MacOS에 여러 MySQL 버전을 설치하고 관리하는 것을 보여줍니다. 홈 브루를 사용하여 설치를 분리하여 갈등을 방지하는 것을 강조합니다. 이 기사에는 설치, 서비스 시작/정지 서비스 및 Best Pra에 대해 자세히 설명합니다

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].

See all articles