INS-40406 报错的出现,让许多人第一反应就是“Grid 目录没清理干净”,于是直接删除 /app/grid/11.2.0 整个文件夹。结果呢?重装时依然卡在同一个错误上,令人困惑不已。实际上,问题的根本原因并不在目录本身,而是 inventory.xml 中缺少了关键的 CRS="true" 标识,或者版本信息不匹配。简单删除目录只会掩盖真正的问题,让排查变得更加复杂。

为什么删除了 /app/grid/11.2.0 仍然报 INS-40406
安装程序并不会扫描 Grid 目录是否存在。它只会读取 /etc/oraInst.loc 所指向的 inventory 路径,然后解析其中的 inventory.xml 文件。具体验证什么?它会检查 HOME 条目是否包含 CRS="true",版本号是否与已知的 GI 安装一致。即使目录删除得再干净,只要 inventory.xml 中还保留着这个条目,安装程序就会认为“存在一条注册记录,但 CRS 实例已经不存在”,于是直接判定没有可升级的有效 GI。结果就是——继续报错。
常见的情况有三种:
inventory.xml中的HOME元素缺少CRS="true"属性 → 安装程序直接忽略该条目SA VED_WITH版本号被某些升级脚本修改成了新版本(例如 11.2.0.4),而实际 Grid 目录中仍是旧版本(如 11.2.0.1)→ 版本校验失败,过程卡住- RAC 环境中只修改了其中一台节点的
inventory.xml→ 其他节点继续报错,集群一致性遭到破坏
必须手动编辑 inventory.xml 的三个关键位置
找到 $ORACLE_BASE/oraInventory/ContentsXML/ 目录(具体路径由 /etc/oraInst.loc 中的 inventory_loc 决定),使用 vi 打开 inventory.xml。需要重点关注三个地方:
- 找到对应 Grid home 的
标签,确保它包含CRS="true"。一个正确的示例是,如果缺少此属性,必须手动补上。 - 检查
的值,它必须与实际部署的 Grid 版本一致。可以通过crsctl query crs activeversion或$GRID_HOME/crs/install/rootcrs.pl -version来确认,避免版本号错误。 - 确认
中的节点名与实际主机名完全一致。注意大小写严格匹配,不能有多余的空格或引号,一个字符都不能错。
配套清理动作:ocr.loc 和 olr.loc 不能留
即使 inventory.xml 已修改正确,残留的 OCR 和 OLR 配置仍可能干扰安装程序,导致集群状态误判。建议执行以下检查:
- 执行
ls -l /etc/oracle/ocr.loc /etc/oracle/olr.loc,如果文件存在,直接删除:rm -f /etc/oracle/ocr.loc /etc/oracle/olr.loc - 不要只关注
ocr.loc——olr.loc是 Oracle Local Registry,在单节点 Oracle Restart 环境下是核心配置。若遗漏删除,后续执行root.sh时必定失败。 - 如果之前已经运行过
rootcrs.pl -deconfig -force,它会自动清理这些文件;但如果没运行过,就需要手动删除,切勿掉以轻心。
验证修复是否生效的最快方式
修改完成后,不要急于直接运行 runInstaller,先使用 Oracle 自带工具进行验证,确保安装程序能够正确识别 GI:
- 切换到 grid 用户,执行
oraenv→ 输入ORACLE_HOME路径 → 然后运行crsctl check crs。正常情况下应显示 “CRS-4638: Oracle High A vailability Services is online” 或提示服务未启动,但至少不会报“找不到命令”。 - 使用
opatch lsinventory -oh $GRID_HOME检查补丁信息是否能正常列出。如果失败,说明inventory.xml的结构仍存在问题。 - 最关键的一步:以安装用户(非 root)执行
runInstaller -executePrereqs -silent -responseFile /path/to/response.rsp,检查 prereq 是否跳过了 INS-40406 错误。
inventory.xml 可以说是 Oracle 安装体系中最脆弱的一环——它不验证路径的真假,只信任 XML 中的每个字符。修改错误的引号或属性名,整个升级流程就会在第一步卡死。动手之前,务必备份原文件。如果是 RAC 环境,所有节点必须同步修改。只要有一个节点不一致,集群添加节点时同样会报错。
