Oracle database SYSAUX 表空间占用率过高处理方案

Oracle database SYSAUX 表空间占用率过高处理方案(WRI$_ADV_OBJECTS)

适用场景:
Oracle 12c/19c SYSAUX 表空间异常暴涨,WRI$_ADV_OBJECTS 及其索引占用几十 GB,数据库告警、空间不足。
核心原因:
统计信息顾问任务(AUTO_STATS_ADVISOR_TASK) 无限生成历史诊断日志,无自动清理机制。

一、问题背景

生产环境 Oracle 数据库 SYSAUX 表空间使用率持续飙升,通过查询发现:

核心占用对象:WRI$_ADV_OBJECTS(表)+ 3 个索引,合计占用 10GB+

该表为Oracle 统计信息顾问任务日志表,仅存储数据库体检历史报告,非业务数据、可安全清理

二、前置检查 SQL

1. 全库表空间使用率查询

SQL 复制代码
-- 表空间使用率统计(GB)
SELECT
    dt.tablespace_name as tablespace,
    dt.contents as type,
    dt.block_size * dtum.used_space /1024/1024/1024 as use_bytes,
    dt.block_size * dtum.tablespace_size /1024/1024/1024 as max_bytes,
    dt.block_size * (dtum.tablespace_size - dtum.used_space) /1024/1024/1024 as free,
    round(dtum.used_percent ,2) as used_percent
FROM  dba_tablespace_usage_metrics dtum, dba_tablespaces dt
WHERE dtum.tablespace_name = dt.tablespace_name
and dt.contents != 'TEMPORARY'
union
SELECT
    dt.tablespace_name as tablespace,
    'TEMPORARY' as type,
    dt.tablespace_size /1024/1024/1024 - dt.free_space /1024/1024/1024 as use_bytes,
    dt.tablespace_size /1024/1024/1024 as max_bytes,
    dt.free_space /1024/1024/1024 as free,
   round( ((dt.tablespace_size - dt.free_space) / dt.tablespace_size )*100 ,2)  AS used_percent
FROM  dba_temp_free_space dt
order by tablespace;

2. SYSAUX 内部对象占用 TOP 查询

sql 复制代码
-- 查看SYSAUX空间占用大户
SELECT 
  owner,segment_name,segment_type,bytes/1024/1024 size_mb
FROM dba_segments 
WHERE tablespace_name='SYSAUX'
ORDER BY bytes DESC;

三、核心清理 SQL

【重要前提】

必须使用 SYS / SYSDBA 执行

优先在业务低峰期操作

1:删除异常统计顾问任务

sql 复制代码
-- 删除导致日志暴增的系统自动任务
DECLARE
  v_tname VARCHAR2(100);
BEGIN
  v_tname := 'AUTO_STATS_ADVISOR_TASK';
  DBMS_STATS.DROP_ADVISOR_TASK(v_tname);
END;
/

说明:删除后不影响业务、不影响统计信息自动收集,仅关闭冗余体检报告。

由于数据堆积、 删除动作会执行很长时间以下为监控任务状态sql

会话 / 事务监控
sql 复制代码
-- 查看SYS用户活动会话
SELECT s.sid, s.serial#, s.status, s.event, s.state, s.seconds_in_wait
FROM v$session s
WHERE s.username = 'SYS' AND s.status = 'ACTIVE' AND s.program LIKE '%sqlplus%';

-- 查看SYS会话运行中的事务(回滚块/处理记录)
SELECT s.sid, 
       s.serial#,
       t.start_time "任务开始时间",
       t.used_ublk "回滚块数",
       t.used_urec "处理记录数"
FROM v$session s, v$transaction t
WHERE s.saddr = t.ses_addr
  AND s.username = 'SYS' 
  AND s.program LIKE '%sqlplus%';
  
-- 重置统计信息包(恢复正常功能)
EXEC DBMS_STATS.INIT_PACKAGE();

2:收缩表 + 重建索引

sql 复制代码
-- 收缩表,降低高水位线
ALTER TABLE WRI$_ADV_OBJECTS MOVE;

-- 重建索引(MOVE后索引失效,必须重建)
ALTER INDEX WRI$_ADV_OBJECTS_PK REBUILD;
ALTER INDEX WRI$_ADV_OBJECTS_IDX_01 REBUILD;
ALTER INDEX WRI$_ADV_OBJECTS_IDX_02 REBUILD;

执行效果:

表 + 索引从 10GB+ → 几 MB

SYSAUX 表空间瞬间回收大量空间

无业务影响(该表为系统日志表,无业务写入)

四、风险说明

ALTER TABLE MOVE / INDEX REBUILD 风险

短暂锁表,低峰期执行无感知

空表下执行速度极快(秒级完成)

删除顾问任务风险

无风险,仅清理历史诊断数据

官方推荐清理方案

不要直接删除SYS核心表
不要在业务高峰期执行 DDL

五、根治方案

sql 复制代码
-- 永久关闭自动统计顾问任务(按需配置)
BEGIN
  DBMS_AUTOTASK_ADMIN.MODIFY_CLIENT(
    client_name => 'auto_stats_advisor',
    operation   => NULL,
    window_name => 'MAINTENANCE_WINDOW_GROUP',
    attribute   => 'ENABLED',
    value       => 'FALSE'
  );
END;
/
相关推荐
A.说学逗唱的Coke18 小时前
【大模型专题】向量数据库深度解析:从原理到实战,构建企业级 AI 知识检索底座
数据库·人工智能
果丁智能18 小时前
智能锁赋能网约房民宿数字化管控:身份核验+远程授权,筑牢安全防线、降本增效
网络·数据库·人工智能·安全·智能家居
无敌的牛18 小时前
redis学习过程
数据库·redis·学习
IT北辰19 小时前
神通数据库管理系统V7.0.251210 for Windows(x86 64bit)安装部署
数据库·神通
北顾笙98019 小时前
MySQL-day2
数据库·mysql
Demons_kirit19 小时前
新项目如何连接上自己本地的数据库
数据库
洪晓露20 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
程序猿乐锅20 小时前
【MySQL | 第八篇】MySQL 视图
数据库·mysql
jieyucx21 小时前
SQL 查询终极高阶通鉴:从零基础拆解到工业级多表联查、窗口函数与索引优化
数据库·sql
ai_coder_ai1 天前
论 NoSQL 数据库技术及其应用
数据库·nosql