Oracle 19c RAC重建AWR步骤详解

Oracle 19c RAC重建AWR步骤详解

  • 一、概述
    • [1.1 什么是AWR?](#1.1 什么是AWR?)
    • [1.2 为什么要重建AWR?](#1.2 为什么要重建AWR?)
    • [1.3 RAC环境特殊性](#1.3 RAC环境特殊性)
  • 二、环境检查
    • [2.1 检查当前AWR配置](#2.1 检查当前AWR配置)
    • [2.2 检查RAC集群状态](#2.2 检查RAC集群状态)
  • 三、重建步骤详解
    • [3.1 停止自动收集](#3.1 停止自动收集)
    • [3.2 删除现有AWR对象](#3.2 删除现有AWR对象)
    • [3.3 重新创建AWR对象](#3.3 重新创建AWR对象)
    • [3.4 编译失效对象](#3.4 编译失效对象)
    • [3.5 配置AWR策略](#3.5 配置AWR策略)
    • [3.6 RAC数据库重启](#3.6 RAC数据库重启)
    • [3.7 创建初始快照](#3.7 创建初始快照)

一、概述

1.1 什么是AWR?

AWR(Automatic Workload Repository)是Oracle数据库的核心性能诊断组件,用于自动收集、处理和维护数据库性能统计信息。它每小时自动生成一次快照,为数据库性能分析和故障诊断提供关键数据支持。

1.2 为什么要重建AWR?

  • 数据损坏:AWR表空间数据损坏或对象失效。
  • 性能问题:AWR相关查询性能下降。
  • 存储清理:清理过期的历史性能数据。
  • 配置重置:恢复默认的AWR收集策略。
  • 故障恢复:解决AWR相关的错误和异常。

1.3 RAC环境特殊性

在Oracle RAC(Real Application Clusters)环境中,AWR数据存储在共享的SYSAUX表空间中,所有集群节点共享同一套AWR数据结构。重建操作会影响整个集群的性能数据收集。

二、环境检查

2.1 检查当前AWR配置

sql 复制代码
-- 查看当前AWR快照设置
SELECT * FROM dba_hist_wr_control;

      DBID SNAP_INTERVAL
---------- ---------------------------------------------------------------------------
RETENTION                                                                   TOPNSQL        CON_ID
--------------------------------------------------------------------------- ---------- ----------
  SRC_DBID
----------
SRC_DBNAME
----------------------------------------------------------------------------------------------------
TABLESPACE_NAME
----------------------------------------------------------------------------------------------------
MOST_RECENT_SNAP_ID MOST_RECENT_SNAP_TIME
------------------- ---------------------------------------------------------------------------
MOST_RECENT_PURGE_TIME                                                      MOST_RECENT_SPLIT_ID
--------------------------------------------------------------------------- --------------------
MOST_RECENT_SPLIT_ STATUS_FLAG REGIS REGISTRATION_TYPE                                AUTO_PUR
------------------ ----------- ----- ------------------------------------------------ --------
2172982360 +00000 01:00:00.0
+00008 00:00:00.0                                                           DEFAULT             0
2172982360
lemon
SYSAUX
                  5 29-DEC-25 01.00.15.511 PM
29-DEC-25 12.24.37.548 PM                                                                      3
29-DEC-25                    0 OK    LOCAL                                            ENABLED


-- 查看详细的快照配置
col SNAP_INTERVAL for a20
col RETENTION for a30
SELECT DBID, SNAP_INTERVAL, SNAPINT_NUM, RETENTION FROM wrm$_wr_control;

      DBID SNAP_INTERVAL        SNAPINT_NUM RETENTION
---------- -------------------- ----------- ------------------------------
2172982360 +00000 01:00:00.0           3600 +00008 00:00:00.0

-- 检查已有快照数量
SELECT COUNT(*) AS snapshot_count FROM dba_hist_snapshot;

SNAPSHOT_COUNT
--------------
            10

-- 查看快照时间范围
SELECT MIN(begin_interval_time) AS earliest,
       MAX(end_interval_time) AS latest
FROM dba_hist_snapshot;

EARLIEST                       LATEST
------------------------------ ------------------------------
25-DEC-25 01.52.43.000 PM      29-DEC-25 01.00.13.419 PM

--
select SNAP_ID,BEGIN_INTERVAL_TIME,END_INTERVAL_TIME from dba_hist_snapshot order by 1 desc

   SNAP_ID BEGIN_INTERVAL_TIME            END_INTERVAL_TIME
---------- ------------------------------ ------------------------------
         5 29-DEC-25 12.07.12.354 PM      29-DEC-25 01.00.13.419 PM
         5 29-DEC-25 12.07.12.151 PM      29-DEC-25 01.00.13.366 PM
         4 29-DEC-25 11.57.09.000 AM      29-DEC-25 12.07.12.354 PM
         4 29-DEC-25 11.56.15.000 AM      29-DEC-25 12.07.12.151 PM
         3 29-DEC-25 10.44.58.000 AM      29-DEC-25 10.55.25.386 AM
         3 29-DEC-25 10.48.01.000 AM      29-DEC-25 10.55.25.742 AM
         2 26-DEC-25 11.26.18.000 AM      26-DEC-25 11.36.19.246 AM
         2 26-DEC-25 11.27.10.000 AM      26-DEC-25 11.36.19.266 AM
         1 25-DEC-25 01.52.43.000 PM      25-DEC-25 01.53.12.514 PM
         1 25-DEC-25 01.52.43.000 PM      25-DEC-25 01.53.05.305 PM

10 rows selected.

2.2 检查RAC集群状态

sql 复制代码
# 检查集群状态
crsctl stat res -t
--------------------------------------------------------------------------------
Name           Target  State        Server                   State details
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.LISTENER.lsnr
               ONLINE  ONLINE       lemon01                  STABLE
               ONLINE  ONLINE       lemon02                  STABLE
ora.chad
               ONLINE  ONLINE       lemon01                  STABLE
               ONLINE  ONLINE       lemon02                  STABLE
ora.net1.network
               ONLINE  ONLINE       lemon01                  STABLE
               ONLINE  ONLINE       lemon02                  STABLE
ora.ons
               ONLINE  ONLINE       lemon01                  STABLE
               ONLINE  ONLINE       lemon02                  STABLE
ora.proxy_advm
               OFFLINE OFFLINE      lemon01                  STABLE
               OFFLINE OFFLINE      lemon02                  STABLE
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.ASMNET1LSNR_ASM.lsnr(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  STABLE
      2        ONLINE  ONLINE       lemon02                  STABLE
ora.DATA.dg(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  STABLE
      2        ONLINE  ONLINE       lemon02                  STABLE
ora.FRA.dg(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  STABLE
      2        ONLINE  ONLINE       lemon02                  STABLE
ora.LISTENER_SCAN1.lsnr
      1        ONLINE  ONLINE       lemon02                  STABLE
ora.OCR.dg(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  STABLE
      2        ONLINE  ONLINE       lemon02                  STABLE
ora.asm(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  Started,STABLE
      2        ONLINE  ONLINE       lemon02                  Started,STABLE
ora.asmnet1.asmnetwork(ora.asmgroup)
      1        ONLINE  ONLINE       lemon01                  STABLE
      2        ONLINE  ONLINE       lemon02                  STABLE
ora.cvu
      1        OFFLINE OFFLINE                               STABLE
ora.lemon.db
      1        ONLINE  ONLINE       lemon01                  Open,HOME=/u01/app/o
                                                             racle/product/19.3.0
                                                             /db,STABLE
      2        ONLINE  ONLINE       lemon02                  Open,HOME=/u01/app/o
                                                             racle/product/19.3.0
                                                             /db,STABLE
ora.lemon01.vip
      1        ONLINE  ONLINE       lemon01                  STABLE
ora.lemon02.vip
      1        ONLINE  ONLINE       lemon02                  STABLE
ora.qosmserver
      1        OFFLINE OFFLINE                               STABLE
ora.scan1.vip
      1        ONLINE  ONLINE       lemon02                  STABLE
--------------------------------------------------------------------------------

三、重建步骤详解

3.1 停止自动收集

sql 复制代码
-- 停止AWR自动快照收集
EXEC DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS(interval=>0);

-- 验证设置
SELECT SNAP_INTERVAL FROM dba_hist_wr_control;

SNAP_INTERVAL
---------------------------------------------------------------------------
+40150 00:00:00.0

说明:

  • 将采集间隔设为0,禁用自动快照。
  • 防止MMON进程在重建过程中写入新数据。
  • RAC环境中,此操作对所有节点立即生效。

3.2 删除现有AWR对象

sql 复制代码
-- 运行删除脚本
@?/rdbms/admin/catnoawr.sql

脚本功能:

  • 删除所有WRH$_开头的表(历史数据)。
  • 删除所有WRF$_开头的表(工作负载数据)。
  • 删除所有WRR$_开头的表(报告数据)。
  • 删除相关的索引、序列、视图。
  • 清理AWR相关的元数据。

注意事项:

  • 执行时间取决于AWR数据量大小。
  • 操作不可逆,确保有完整备份。
  • 在RAC的一个节点执行即可。
  • 监控UNDO表空间使用情况。

3.3 重新创建AWR对象

sql 复制代码
-- 运行创建脚本
@?/rdbms/admin/catawrtb.sql

脚本功能:

  • 创建新的AWR表结构
  • 建立必要的分区(按时间范围分区)
  • 创建所有必需的索引
  • 初始化序列和约束
  • 设置初始存储参数

3.4 编译失效对象

sql 复制代码
-- 第一次编译
@?/rdbms/admin/utlrp.sql

-- 等待编译完成后验证编译结果
@?/rdbms/admin/execsvrm.sql

-- 如果有报错信息对象,再次编译无效对象
@?/rdbms/admin/utlrp.sql

关键点:

  • utlrp.sql可能需运行多次
  • execsvrm.sql必须无错误输出
  • 在RAC环境,编译结果对所有节点生效
  • 监控编译过程中的资源使用

3.5 配置AWR策略

sql 复制代码
-- 设置新的采集策略(示例:每30分钟一次,保留8天)
exec DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS(interval=>30, retention=>8*24*60);

-- 验证配置
SELECT * FROM dba_hist_wr_control;


      DBID SNAP_INTERVAL
---------- ---------------------------------------------------------------------------
RETENTION                                                                   TOPNSQL        CON_ID
--------------------------------------------------------------------------- ---------- ----------
  SRC_DBID
----------
SRC_DBNAME
----------------------------------------------------------------------------------------------------
TABLESPACE_NAME
----------------------------------------------------------------------------------------------------
MOST_RECENT_SNAP_ID MOST_RECENT_SNAP_TIME
------------------- ---------------------------------------------------------------------------
MOST_RECENT_PURGE_TIME                                                      MOST_RECENT_SPLIT_ID
--------------------------------------------------------------------------- --------------------
MOST_RECENT_SPLIT_ STATUS_FLAG REGIS REGISTRATION_TYPE                                AUTO_PUR
------------------ ----------- ----- ------------------------------------------------ --------
2172982360 +00000 00:30:00.0
+00008 00:00:00.0                                                           DEFAULT             0
2172982360
lemon
SYSAUX
                  0 15-JAN-26 05.23.04.249 PM
15-JAN-26 05.23.04.249 PM                                                                      0
15-JAN-26                    0 OK    LOCAL                                            ENABLED

参数说明:

参数 建议值 说明
interval 60 每60分钟采集一次(1小时)
retention 43200 保留30天数据(30×24×60)
topnsql DEFAULT 保留的SQL数量,默认根据SYSAUX空间自动调整

3.6 RAC数据库重启

sql 复制代码
# 按实例逐个重启
srvctl stop instance -d lemon -i lemon1
srvctl start instance -d lemon -i lemon1

srvctl stop instance -d lemon -i lemon2
srvctl start instance -d lemon -i lemon2

3.7 创建初始快照

sql 复制代码
-- 手动创建第一个快照
EXEC DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();

-- 验证快照创建
SELECT snap_id, 
       begin_interval_time, 
       end_interval_time,
       instance_number
FROM dba_hist_snapshot 
ORDER BY snap_id DESC 
FETCH FIRST 5 ROWS ONLY;
   SNAP_ID BEGIN_INTERVAL_TIME            END_INTERVAL_TIME              INSTANCE_NUMBER
---------- ------------------------------ ------------------------------ ---------------
         1 15-JAN-26 05.26.28.000 PM      15-JAN-26 05.28.30.525 PM                    1
         1 15-JAN-26 05.28.17.000 PM      15-JAN-26 05.28.32.901 PM                    2
相关推荐
wengad1 天前
podman搭建nginx服务
运维·nginx·podman
马克学长1 天前
SSM在浙智游bjl48(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·浙智游系统·景点信息管理
阡陌..1 天前
Linux下的vi和vim使用方法
linux·运维·vim
hweiyu001 天前
Linux 命令:diff
linux·运维·服务器
姚远Oracle ACE1 天前
Step-by-Step: 在 Linux 上使用 VMware 安装 Oracle 26ai RAC 数据库
linux·数据库·oracle
进击切图仔1 天前
基于 linux 20.04 构建 ros1 noetic 开发环境 -离线版本
linux·运维·服务器
starcat20021 天前
ESXi安装直连显卡的KDE-NEON
linux
EmbedLinX1 天前
Linux 之设备驱动
linux·服务器·c语言
naruto_lnq1 天前
如何为开源Python项目做贡献?
jvm·数据库·python
vortex51 天前
Alpine Linux syslinux 启动加固(密码保护)
linux·服务器·网络