相信在 Redhat 7 上安装过 Oracle 12CR2 RAC 的装避朋友,看了本文一定会后悔没有早点看到这篇完美的坑宝避坑指南!
😜 如果有朋友不信邪,装避可以按照常规的坑宝方式安装,大概率是装避会遇到下面我列出的这些坑。
本文主要介绍 Redhat 7.6 系统安装 Oracle 12201 版本 RAC 的装避一些坑以及避坑方式。
绝对干货满满,坑宝物超所值,装避当然更欢迎大家来补充和纠错!
📢 注意: 坑点主要位于 Grid 软件安装步骤中 cvu check 和 root.sh 执行。坑宝
Grid 软件安装过程检查报错:Shared Storage Accessibility:/dev/asm_ocr ...FAILED (PRVG-11506)
可参照 MOS 文档:
这里先卖个关子,装避不说解决方案,坑宝MOS 建议是装避打一个补丁 25784424 来修复:
😤 先吐槽一下,这 TM 简直巨坑无比!
当执行 root.sh 命令到进度 14/19 时,突然停止并且报错 CLSRSC-400,并提示重启主机系统,重启之后安装进程已经终止,继续执行依然报错,无奈卸载重装,结果依然报错,当时搞了将近 3 个多小时,网上找遍了都没发现相关问题,真是一把心酸泪 😢!
在 MOS 上找了个相关文档,但没解决问题,可以参考一下:
MOS 建议仍然是通过 applyOneOffs 打补丁来修复:
📢 注意: 这里虽然没有帮助我解决问题,但是帮我打开了一个思路,让我想到了 12C 开始支持的新的打补丁方式 applyPSU,对我后面解决问题带来了很大的帮助!
在修复了上述 2 个问题之后,😀 我又高高兴兴的开始执行 root.sh,看着一路畅通无阻,本想着收拾收拾回家了。
结果 root.sh 执行到进度 19/19 时,突然报错停止,报错内容为:kgfnGetConnDetails requires 4 parameters at/u01/app/12.2.0/grid/lib/asmcmdbase.pm line 5704,显示 root.sh 执行失败。
此时,我不认命的觉得它安装成功,去试了下 asmcmd 命令,我直接裂开了 😵!
好吧,放下书包,看报错日志,然后 MOS 一通发现了下面这些文档,以供参考:
这个问题还算简单,但是还要卸载重装一遍,最后经过九九八一难,使出九牛二虎之力,终于把 Grid 软件安装成功了,后面 Oracle 软件安装和建库都尤为顺利。
聊完了有哪些坑,下面当然要说说怎么避开了!
之前坑 2 有个 MOS 说要使用 applyOneOffs 打补丁来修复,于是就去搜了一下这个参数的用法,发现可以在 Grid 软件安装前打上补丁,顺带着还发现了 applyPSU,感觉找到了出路!
当时我使用 MOS 的方式进行单个补丁修复,结果一个又一个,感觉没完了一样,后来转念一想,PSU 季度补丁是包含之前的 BUG 修复补丁的,直接使用 applyPSU 提前打上季度补丁来进行修复,就没那么多问题,值得一试!
参考上述 MOS 文档,有详细的介绍和使用方法。
通过 12C 开始支持的 applyPSU 方式,提前给 Grid 软件打上最新的季度 PSU 补丁,修复坑 1,2 的 BUG:
1、解压 OPatch 补丁包
- ## grid 用户下执行解压,覆盖 OPatch 旧版本
- unzip -o /soft/p6880880_122010_Linux-x86-64.zip -d /u01/app/12.2.0/grid/
2、查看 OPatch 补丁包版本
- ## grid 用户下执行
- /u01/app/12.2.0/grid/OPatch/opatch version
- OPatch Version: 12.2.0.1.24
3、解压最新 PSU 补丁
- ## grid 用户下执行
- unzip /soft/p32226491_122010_Linux-x86-64.zip -d /soft
📢 注意: 由于本文是在 2021年1月份写的,所以补丁包版本非最新,请下载当前最新的 PSU 补丁包!
4、执行 Grid 软件安装
- ## grid 用户下执行
- ./gridSetup.sh -applyPSU /soft/32226491
- Preparing the home to patch...
- Applying the patch /soft/32226491/...
- Successfully applied the patch.
- The log can be found at: /u01/app/oraInventory/logs/GridSetupActions2021-04-01_04-18-54PM/installerPatchActions_2021-04-01_04-18-54PM.log
- Launching Oracle Grid Infrastructure Setup Wizard...
通过上述命令执行结果,可以看到成功安装了 PSU 补丁后才开始安装 Grid 软件!
📢 注意: 当通过上述方式提前安装了 PSU 补丁后,后面简直可以说是一帆风顺,直到执行 root.sh 到最后一步,遇到了坑 3。
这个问题很简单,只需要执行一行命令即可,但是要注意执行命令的时机。
- ## 在 root 用户下执行,需要提前配置 grid 软件的 ORACLE_HOME 环境变量
- /usr/bin/make -f $ORACLE_HOME/rdbms/lib/ins_rdbms.mk client_sharedlib libasmclntsh12.ohso libasmperl12.ohso ORACLE_HOME=$ORACLE_HOME
执行顺序:
当 Grid 软件安装 执行到出现 root.sh 提示框时,执行以上命令,📢 需在两个节点以root 身份执行该命令,ORACLE_HOME 路径请根据实际情况填写!确保所有节点执行完之后,再执行 root.sh,就可以完美修复坑 3。
接下来,就是顺风顺水,常规安装步骤了!不过,有 19C 了谁还用 12C 呢?😎
咱们上面讲的几个坑,说白了都是 BUG,解决方案都是通过补丁来修复。事后我就在想,官方为什么不在安装之前先把补丁都打上呢?这样不就可以避免这些 BUG 报错嘛!
于是,我在试着整了一版打好 PSU 的 12C GRID 安装包,下面介绍一下如何操作!
通过以下👇🏻 两个参数可以将基础安装包和补丁包进行集成打包。
集成目的: 安装时可以省去安装补丁的步骤,直接解压集成安装包安装即可!
以下举例 12CR2 Grid 集成补丁包 32540149 步骤:
(1)上传安装介质
- ##Grid基础安装包
- LINUX.X64_122010_grid_home.zip
- ##OPatch补丁包
- p6880880_122010_Linux-x86-64.zip
- ##PSU补丁包
- p32540149_122010_Linux-x86-64.zip
- ##Oracle一键配置脚本
- OracleShellInstall.sh
(2)配置主机环境
使用我编写的 Oracle 一键安装脚本进行环境配置:
- ./OracleShellInstall.sh -i 10.211.55.100 `#Public ip`\
- -n restart `# hostname`\
- -o nocdb `# oraclesid`\
- -gp oracle `# grid user password`\
- -op oracle `# oracle user password`\
- -b /oracle/app `# install basedir`\
- -s AL32UTF8 `# characterset`\
- -m Y
(3)安装补丁
分别解压 OPatch 补丁包和 PSU 补丁包:
- ##解压更新OPatch包
- unzip -o p6880880_122010_Linux-x86-64.zip -d /oracle/app/12.2.0/grid
- chown -R grid:oinstall /oracle/app/12.2.0/grid/OPatch
- ##解压PSU补丁包
- unzip p32540149_122010_Linux-x86-64.zip /soft
- chown -R grid:oinstall /soft/32540149
Grid 安装好补丁,但是不执行安装过程:
- su - grid -c "/oracle/app/12.2.0/grid/gridSetup.sh -applyPSU /soft/32540149"
- ## 安装成功后
- ## 1.修复bug:
- ## [INS-42505] The installer has detected that the Oracle Grid Infrastructure home software at (/oracle/GRID/12201) is not complete. (Doc ID 2697235.1)
- mv $ORACLE_HOME/install/files.lst $ORACLE_HOME/install/files.lst.bak
📢 注意: 上面遇到这个小 BUG,也可以无视,没有什么大影响。
(4)压缩 ORACLE_HOME 目录
这里我将安装好的 Grid ORACLE_HOME 压缩打包成 zip 安装包:
- cd /oracle/app/12.2.0/grid/
- zip -r LINUX.X64_122010_grid_home_32540149.zip *
- mv LINUX.X64_122010_grid_home_32540149.zip /soft
至此,基础安装包和补丁包集成成功。
这里我们打开一台新的主机进行安装测试。
(1)上传集成安装包等介质
- ##Grid集成安装包
- LINUX.X64_122010_grid_home_32540149.zip
- ##Oracle一键配置脚本
- OracleShellInstall.sh
(2)主机环境初始化配置
- ##iscsi挂载共享盘
- iscsiadm -m discovery -t st -p 10.211.55.22
- iscsiadm -m node -T iqn.2008-08.com.starwindsoftware:10.211.55.22-lucifer -p 10.211.55.22 -l
- ##重命名安装包
- mv LINUX.X64_122010_grid_home_32540149.zip LINUX.X64_122010_grid_home.zip
- ##执行脚本初始化配置
- cd /soft
- ./OracleShellInstall.sh -i 10.211.55.100 `#Public ip`\
- -n restart `# hostname`\
- -o nocdb `# oraclesid`\
- -gp oracle `# grid user password`\
- -op oracle `# oracle user password`\
- -b /u01/app `# install basedir`\
- -s AL32UTF8 `# characterset`\
- -dd /dev/sdc `# asm data disk`\
- -dn DATA `# asm data diskgroupname`\
- -dr EXTERNAL `# asm data redundancy`\
- -m Y
(3)安装 Grid 软件
- su - grid
- cd /oracle/app/12.2.0/grid/
- ./gridSetup.sh
执行 root.sh 前执行:
- ## 2.修复bug:ASMCMD Failing With "KGFNGETCONNDETAILS Requires 4 Parameters at <GI_HOME>/lib/asmcmdbase.pm (Doc ID 2748316.1)
- export ORACLE_HOME=/u01/app/12.2.0/grid
- /usr/bin/make -f $ORACLE_HOME/rdbms/lib/ins_rdbms.mk client_sharedlib libasmclntsh12.ohso libasmperl12.ohso ORACLE_HOME=$ORACLE_HOME
顺利安装完毕!虽然实际用处不大,也算是一个思路吧,可以节省一些时间。
责任编辑:姜华 来源: Lucifer三思而后行 Oracle数据库后端开发
(责任编辑:热点)
爱美客(300896.SZ)年报推10转8派35元 除权除息日为2021年3月16日
如何在Windows 10中使用Win7/Win8.1桌面背景设置窗口
在四大数据管理使用案例中全胜,Teradata客户始终保持极高忠诚度
价值10亿仓单融资“一女多嫁”造成爆雷,物联网如何避免此类风险
隐私计算国际赛事iDASH2022揭榜 中国公司在四大赛道中斩获三项第一
彩讯股份(300634.SZ):股东广东达盛累计减持437.99万股
狂裁 2000 人,大众软件部两年亏 260 亿,高管曾集体被炒