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;
/