1. 程式人生 > >Oracle 11g 清理SYSAUX空間

Oracle 11g 清理SYSAUX空間

 SYSAUX表空間做為SYSTEM表空間的輔助表空間,主要存放EM相關的內容以及表統計資訊,AWR快照,審計資訊等。今天就碰到了這個問題,資料庫較慢,奇怪的是無法獲取AWR報告。

SQL> select * from v$version;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE    11.2.0.4.0      Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
--擷取獲取資料庫報告的片段,正常是顯示快照id

輸入 num_days 的值:  1
Listing the last 1 days of Completed Snapshots
--手工生成快照儲存,很明顯是表空間不足
SQL> exec dbms_workload_repository.create_snapshot();
BEGIN dbms_workload_repository.create_snapshot(); END;
*
第 1 行出現錯誤:
ORA-13509: 更新 AWR 表時出錯
ORA-01683: 索引 ORA-01683: 索引 SYS.WRH$_ACTIVE_SESSION_HISTORY_PK 分割槽 WRH$_ACTIVE_1148453265_0 無法通過 8192 (在表空間 SYSAUX 中) 擴充套件
. 分割槽  無法通過  (在表空間  中) 擴充套件
ORA-06512: 在 "SYS.DBMS_WORKLOAD_REPOSITORY", line 99
ORA-06512: 在 "SYS.DBMS_WORKLOAD_REPOSITORY", line 122
ORA-06512: 在 line 1
--查詢SYSAUX表空間的使用情況,消耗37G,快滿了
SQL> SELECT Upper(F.TABLESPACE_NAME)         "表空間名",
           D.TOT_GROOTTE_MB                 "表空間大小(M)",
           D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)",
           To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99')
           || '%'                           "使用比",
           F.TOTAL_BYTES                    "空閒空間(M)",
           F.MAX_BYTES                      "最大塊(M)"
    FROM   (SELECT TABLESPACE_NAME,
                   Round(Sum(BYTES) / ( 1024 * 1024 ), 2) TOTAL_BYTES,
                   Round(Max(BYTES) / ( 1024 * 1024 ), 2) MAX_BYTES
            FROM   SYS.DBA_FREE_SPACE
            GROUP  BY TABLESPACE_NAME) F,
           (SELECT DD.TABLESPACE_NAME,
                   Round(Sum(DD.BYTES) / ( 1024 * 1024 ), 2) TOT_GROOTTE_MB
            FROM   SYS.DBA_DATA_FILES DD
            GROUP  BY DD.TABLESPACE_NAME) D
    WHERE  D.TABLESPACE_NAME = F.TABLESPACE_NAME
    and D.tablespace_name = 'SYSAUX';
表空間名  表空間大小(M) 已使用空間(M) 使用比   空閒空間(M)  最大塊(M)
--------- ------------- ------------- -------- ----------- ----------
SYSAUX         37887.98       37865.6   99.94%       22.38          1
--檢視SYSAUX表空間表的使用情況
SQL> select *
       from (select segment_name,
                    segment_type,
                    bytes / 1024 / 1024
               from dba_segments
              where tablespace_name = 'SYSAUX'
              and bytes / 1024 / 1024 >1000
              order by bytes desc);
SEGMENT_NAME                          SEGMENT_TYPE       BYTES/1024/1024
------------------------------------- ------------------ ---------------
WRH$_ACTIVE_SESSION_HISTORY           TABLE PARTITION       13479
I_WRI$_OPTSTAT_H_OBJ#_ICOL#_ST        INDEX                 2590
WRI$_OPTSTAT_HISTGRM_HISTORY          TABLE                 2242
WRH$_EVENT_HISTOGRAM_PK               INDEX PARTITION       1856
WRH$_EVENT_HISTOGRAM                  TABLE PARTITION       1792
I_WRI$_OPTSTAT_H_ST                   INDEX                 1544
WRH$_ACTIVE_SESSION_HISTORY_PK        INDEX PARTITION       1472
WRH$_LATCH                            TABLE PARTITION       1155


--使用dbms_workload_repository.drop_snapshot_range可以刪除歷史資料,怎奈太慢了,半個小時完全沒有反映。通過v$session看到執行的SQL是delete,這種做法無法降低高水位線。

SQL> select min(snap_id),max(snap_id) from dba_hist_snapshot;
MIN(SNAP_ID) MAX(SNAP_ID)
------------ ------------
SQL> select min(snap_id),max(snap_id) from dba_hist_active_sess_history;
MIN(SNAP_ID) MAX(SNAP_ID)
------------ ------------
1             36768
SQL> begin 
     dbms_workload_repository.drop_snapshot_range( 
      low_snap_id => 1, 
      high_snap_id => 36768, 
      dbid => 1148453265); 
end; 


--手工生成truncate,需要在SYS下執行

select distinct 'truncate  table  '||segment_name||';',s.bytes/1024/1024
  from dba_segments s
 where s.segment_name like 'WRH$%'
   and segment_type in ('TABLE PARTITION', 'TABLE')
   and s.bytes/1024/1024>100
   order by s.bytes/1024/1024/1024 desc;
   
--執行完成後,看效果
SQL> SELECT Upper(F.TABLESPACE_NAME)         "表空間名",
          D.TOT_GROOTTE_MB                 "表空間大小(M)",
          D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空間(M)",
          To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99')
          || '%'                           "使用比",
          F.TOTAL_BYTES                    "空閒空間(M)",
          F.MAX_BYTES                      "最大塊(M)"
   FROM   (SELECT TABLESPACE_NAME,
                  Round(Sum(BYTES) / ( 1024 * 1024 ), 2) TOTAL_BYTES,
                  Round(Max(BYTES) / ( 1024 * 1024 ), 2) MAX_BYTES
           FROM   SYS.DBA_FREE_SPACE
           GROUP  BY TABLESPACE_NAME) F,
          (SELECT DD.TABLESPACE_NAME,
                  Round(Sum(DD.BYTES) / ( 1024 * 1024 ), 2) TOT_GROOTTE_MB
           FROM   SYS.DBA_DATA_FILES DD
           GROUP  BY DD.TABLESPACE_NAME) D
   WHERE  D.TABLESPACE_NAME = F.TABLESPACE_NAME
   and D.tablespace_name = 'SYSAUX';
表空間名  表空間大小(M) 已使用空間(M) 使用比   空閒空間(M)  最大塊(M)
--------- ------------- ------------- -------- ----------- ----------
SYSAUX         37887.98       9132.67   24.10%    28755.31        544
--------------------- 
作者:深圳gg 
來源:CSDN 
原文:https://blog.csdn.net/stevendbaguo/article/details/53745661 
版權宣告:本文為博主原創文章,轉載請附上博文連結!