Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03

Oracle Health Check巡检脚本使用SOP V1.0https://blog.csdn.net/weixin_45806267/article/details/161506734?spm=1001.2014.3001.5501

一、适用范围

本 SOP 适用于 Linux/Unix 类操作系统上的 Oracle 数据库服务器巡检

说明:

  • 本文示例以 Linux 系统为准;

  • Windows 环境不适用 oscheck.sh,应使用对应的 Windows/PowerShell 版本脚本;

  • 本脚本适用于 Oracle CDB/PDB 架构和非 CDB 架构数据库巡检。


二、脚本组成与关系

本次巡检使用 3 个脚本:

脚本名称 作用
oscheck.sh 巡检入口脚本,负责采集主机 OS、Oracle 环境、监听、补丁、RAC/GI 信息,并自动调用数据库巡检 SQL
dbcheck_cdb.sql Oracle CDB/PDB 架构数据库巡检 SQL
dbcheck_noncdb.sql Oracle 非 CDB 架构数据库巡检 SQL

三个脚本之间不是内容包含关系 ,而是调用关系

复制代码
oscheck.sh
   ├── 采集主机 OS、Oracle 环境、监听、补丁、RAC/GI 信息
   └── 自动调用对应的 dbcheck 脚本
        ├── CDB/PDB 架构:调用 dbcheck_cdb.sql
        └── 非 CDB 架构:调用 dbcheck_noncdb.sql

注意:

  • oscheck.sh 是总入口;

  • dbcheck_cdb.sqldbcheck_noncdb.sql 是被调用脚本;

  • oscheck.sh 不包含两个 dbcheck 脚本的完整内容;

  • 三个脚本必须放在同一目录下。


三、ODA 多 CDB 执行原则

在 ODA 环境中,可能存在一套 ODA 上部署多个 CDB 的情况,例如:

复制代码
一套 ODA
├── CDB1
│   ├── PDB1
│   └── PDB2
└── CDB2
    ├── PDB1
    └── PDB2

该场景下,巡检按 CDB 维度 执行:

  • 一个 CDB 执行一次巡检;

  • CDB 下的 PDB 信息由 dbcheck_cdb.sql 自动采集;

  • 不需要对每个 PDB 单独执行;

  • 如果一套 ODA 上有 2 个 CDB,则需要分别执行 2 次巡检。

-o 参数后面填写的是当前节点本地 Oracle 实例名,即 ORACLE_SID

不要填写:

  • PDB 名;

  • 业务系统名称;

  • 数据库资源名。

ODA 多 CDB 示例

先在当前节点确认本机正在运行的 Oracle 实例:

复制代码
ps -ef | grep "[p]mon"

示例输出:

复制代码
ora_pmon_ERPCDB1
ora_pmon_MESDB1

说明:

ora_pmon_ 后面的内容就是当前节点本地实例名,也就是需要设置的 ORACLE_SID

根据上面示例,当前节点有两个 CDB 实例:

CDB/数据库 当前节点本地实例名 巡检方式
ERPCDB ERPCDB1 设置 ORACLE_SID=ERPCDB1 后执行
MESDB MESDB1 设置 ORACLE_SID=MESDB1 后执行

第一次巡检 ERPCDB:

复制代码
export ORACLE_SID=ERPCDB1
bash oscheck.sh -o $ORACLE_SID

第二次巡检 MESDB:

复制代码
export ORACLE_SID=MESDB1
bash oscheck.sh -o $ORACLE_SID

如果在另一个节点执行,也要先确认当前节点本地实例名。例如另一个节点可能显示:

复制代码
ora_pmon_ERPCDB2
ora_pmon_MESDB2

则对应执行:

复制代码
export ORACLE_SID=ERPCDB2
bash oscheck.sh -o $ORACLE_SID

export ORACLE_SID=MESDB2
bash oscheck.sh -o $ORACLE_SID

四、脚本部署

脚本目录可根据现场实际情况选择,/data/check 只是示例路径。

例如可以使用:

复制代码
/data/check
/u01/check
/home/oracle/check

本文以 /data/check 为例。

使用 root 用户创建目录:

复制代码
mkdir -p /data/check

将以下 3 个脚本上传到同一目录:

复制代码
oscheck.sh
dbcheck_cdb.sql
dbcheck_noncdb.sql

检查脚本:

复制代码
cd /data/check
ll

正常应看到:

复制代码
oscheck.sh
dbcheck_cdb.sql
dbcheck_noncdb.sql

五、脚本授权

使用 root 用户执行:

复制代码
cd /data/check
chown -R oracle:oinstall /data/check
chmod 750 /data/check
chmod 750 oscheck.sh
chmod 640 dbcheck_cdb.sql dbcheck_noncdb.sql

如果现场 Oracle 用户组不是 oinstall,以实际查询结果为准:

复制代码
id oracle

授权后权限示例:

复制代码
-rwxr-x--- 1 oracle oinstall oscheck.sh
-rw-r----- 1 oracle oinstall dbcheck_cdb.sql
-rw-r----- 1 oracle oinstall dbcheck_noncdb.sql

六、执行前检查

切换到 oracle 用户:

复制代码
su - oracle
cd /data/check

确认 Oracle 环境:

复制代码
echo $ORACLE_SID
echo $ORACLE_HOME
ps -ef | grep "[p]mon"

确认要求:

  • ORACLE_HOME 正确;

  • ORACLE_SID 为当前节点本地实例名;

  • ORACLE_SID 应与 ora_pmon_ 后面的实例名一致。

如果当前 ORACLE_SID 不正确,先手动指定:

复制代码
export ORACLE_SID=当前节点本地实例名

七、执行巡检

执行命令:

复制代码
bash oscheck.sh -o $ORACLE_SID

也可以明确指定实例名:

复制代码
bash oscheck.sh -o yjcs

说明:

  • -o 后面填写 Oracle 实例名;

  • RAC/ODA 环境填写当前节点本地实例名;

  • CDB/PDB 架构下只需要对 CDB 实例执行;

  • PDB 不需要单独执行巡检。

执行过程中,如检测到 CDB 架构,会显示:

复制代码
检测到 CDB 架构,使用 dbcheck_cdb.sql

八、查看结果

执行完成后,在脚本目录查看结果:

复制代码
ls -lh /data/check

正常会生成:

复制代码
dbcheck_主机名_日期/
dbcheck_主机名_日期.tar.gz

其中 .tar.gz 文件就是最终巡检结果包。

ODA 多 CDB 场景下,如果同一天在同一目录连续巡检多个 CDB,结果包名称可能相同。建议每个 CDB 使用独立目录,或执行完成后按 CDB 名称单独保存结果包,例如:

复制代码
dbcheck_ERPCDB1_主机名_日期.tar.gz
dbcheck_MESDB1_主机名_日期.tar.gz

九、注意事项

  1. 本脚本主要适用于 Linux/Unix 类 Oracle 数据库服务器;

  2. 不建议使用 root 用户直接执行 oscheck.sh

  3. 三个脚本必须放在同一目录;

  4. /data/check 只是示例路径,实际可按现场目录调整;

  5. ODA 多 CDB 场景下,按 CDB 维度执行巡检;

  6. -o 后填写当前节点本地实例名,即 ORACLE_SID

  7. PDB 不需要单独执行巡检;

  8. 建议在业务低峰期执行;

  9. 巡检结果包含主机、数据库、用户、权限、表空间、补丁等敏感信息,应妥善保存;

  10. 本脚本属于巡检采集类脚本,不属于数据库变更脚本。


十、标准执行流程汇总

1. root 用户准备

复制代码
mkdir -p /data/check
cd /data/check

chown -R oracle:oinstall /data/check
chmod 750 /data/check
chmod 750 oscheck.sh
chmod 640 dbcheck_cdb.sql dbcheck_noncdb.sql

2. oracle 用户执行

复制代码
su - oracle
cd /data/check

echo $ORACLE_HOME
ps -ef | grep "[p]mon"

export ORACLE_SID=当前节点本地实例名
bash oscheck.sh -o $ORACLE_SID

3. 查看结果

复制代码
ls -lh /data/check

十一、附录:涉及的脚本源码

说明:以下源码仅用于留档和版本核对。日常执行时按前文 SOP 操作即可,不建议把源码插入到操作步骤中。

附录 A:oscheck.sh

此处粘贴 oscheck.sh 脚本全文。

复制代码
请私信本人获取

附录 B:dbcheck_cdb.sql

此处粘贴 dbcheck_cdb.sql 脚本全文。

复制代码
请私信本人获取

附录 C:dbcheck_noncdb.sql

此处粘贴 dbcheck_noncdb.sql 脚本全文。

复制代码
请私信本人获取
相关推荐
Database_Cool_3 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
广州灵眸科技有限公司3 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) Linux虚拟机准备
linux·运维·服务器
我是一颗柠檬3 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存
sukioe3 小时前
Redis 持久化+高可用详解:RDB/AOF/混合/主从/哨兵/集群
数据库·redis·缓存
全栈软件开发4 小时前
祈福导航系统V1.1更新 优化后端控制逻辑和前台UI
数据库·祈福导航系统
Lana学习中4 小时前
【运维杂记】连接不上远程服务器的问题处理
运维·服务器
_qingche5 小时前
H2 数据库到 MySQL 数据迁移
java·数据库·spring boot·mysql·spring·重构·kotlin
AOwhisky5 小时前
MySQL 学习笔记(第一期):数据库基础与 MySQL 初探
运维·数据库·笔记·学习·mysql·云计算
Peace5 小时前
【Prometheus】
linux·运维·prometheus