oracle sysaux扩大,Oracle表空间SYSAUX使用率很高解决案例

本实例主要针对Oracle表空间饱满问题处理方法做个步骤分享。

一、告警信息

收到zabbix告警信息,表空间 SYSAUX 使用率>95%%,系统表空间sysaux使用率超过了95%。

c85eadc13f88ab7fcd8a4ab7302a9cf1.png

二、处理步骤

1.登录具体数据库做相应的数据库空间使用率查询

set line 200;

set pagesize 20000;

set feedback off;

col tablespace_name for a20;

col c_free_percent for a12;

col c_used_percent for a12;

col m_free_percent for a12;

col m_USED_PERCENT for a12;

select d.tablespace_name,round(d.MB_current_Bytes,2) Curr_Size_MB,round(f.free_mb_bytes,2) Free_Szie_MB,round(d.MB_maxbytes,2) MAX_Size_MB,round((f.free_mb_bytes/d.MB_current_Bytes)*100,2)  c_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_current_Bytes,4)*100 || '%' c_used_percent,round(((d.MB_maxbytes-d.MB_current_Bytes+f.free_mb_bytes)/d.MB_maxbytes)*100,2)  m_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_maxbytes,4)*100 || '%' m_used_percent

from  (select tablespace_name,sum(bytes/1024/1024) MB_current_Bytes,sum(maxbytes/1024/1024) MB_maxbytes from dba_data_files group by tablespace_name ) d,(select tablespace_name,sum(bytes/1024/1024) free_mb_bytes from dba_free_space group by tablespace_name) f

where d.tablespace_name=f.tablespace_name

order by c_free_percent ;

ad02381f08e01d3218e94e5e066a26df.png

2.查询表空间对应的对象占用情况

select OWNER,segment_name,segment_type,PARTITION_NAME,bytes/1024/1024/1024 Size_GB from dba_segments  where tablespace_name='SYSAUX' order by Size_GB desc

9bd721aa050f8ec72fbad6ed97b45b47.png

3.根据具体大对象做排查,对可以清理的相关数据清理

根据上述SQL查到的大对象主要是

1    SYS    WRH$_LATCH_CHILDREN        WRH$_LATCH__1153813778_29290    TABLE PARTITION    29.927734375

2    SYS    WRH$_LATCH_CHILDREN_PK     WRH$_LATCH__1153813778_29290    INDEX PARTITION    14.984375

3    SYS    WRH$_ACTIVE_SESSION_HISTORY  WRH$_ACTIVE_1153813778_29290    TABLE PARTITION    3.6474609375

4    SYS    WRH$_SQLSTAT            WRH$_SQLSTA_1153813778_29290    TABLE PARTITION    1.2529296875

WRH$_LATCH_CHILDREN 表示快照使用的,其中分区1153813778是DBID, 29290是快照ID

查看29290的快照ID是什么时间的

select snap_id, begin_interval_time from sys.dba_hist_snapshot order by snap_id;

select snap_id, begin_interval_time from sys.dba_hist_snapshot where snap_id=29290

2f4ae66aaccd86a1d8d7c837a8dde74c.png

4.清空分区WRH$_LATCH__1153813778_29290

select * from  WRH$_LATCH_CHILDREN partition ( WRH$_LATCH__1153813778_29290);

alter table WRH$_LATCH_CHILDREN truncate partition WRH$_LATCH__1153813778_29290;

5.清理后表空间查看

select d.tablespace_name,round(d.MB_current_Bytes,2) Curr_Size_MB,round(f.free_mb_bytes,2) Free_Szie_MB,round(d.MB_maxbytes,2) MAX_Size_MB,round((f.free_mb_bytes/d.MB_current_Bytes)*100,2)  c_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_current_Bytes,4)*100 || '%' c_used_percent,round(((d.MB_maxbytes-d.MB_current_Bytes+f.free_mb_bytes)/d.MB_maxbytes)*100,2)  m_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_maxbytes,4)*100 || '%' m_used_percent

from  (select tablespace_name,sum(bytes/1024/1024) MB_current_Bytes,sum(maxbytes/1024/1024) MB_maxbytes from dba_data_files group by tablespace_name ) d,(select tablespace_name,sum(bytes/1024/1024) free_mb_bytes from dba_free_space group by tablespace_name) f

where d.tablespace_name=f.tablespace_name  and f.tablespace_name='SYSAUX'order by c_free_percent ;

aa45f62dda4aa4971f909f0a7e5756c1.png

三、脚本附录

1.表空间segment大小查询

select OWNER,segment_name,PARTITION_NAME,segment_type,bytes/1024/1024/1024 Size_GB from dba_segments  where tablespace_name='SYSAUX' order by Size_GB desc

2.表空间使用率查询

set line 200;

set pagesize 20000;

set feedback off;

col tablespace_name for a20;

col c_free_percent for a12;

col c_used_percent for a12;

col m_free_percent for a12;

col m_USED_PERCENT for a12;

select d.tablespace_name,round(d.MB_current_Bytes,2) Curr_Size_MB,round(f.free_mb_bytes,2) Free_Szie_MB,round(d.MB_maxbytes,2) MAX_Size_MB,round((f.free_mb_bytes/d.MB_current_Bytes)*100,2)  c_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_current_Bytes,4)*100 || '%' c_used_percent,round(((d.MB_maxbytes-d.MB_current_Bytes+f.free_mb_bytes)/d.MB_maxbytes)*100,2)  m_free_percent,round((d.MB_current_Bytes-f.free_mb_bytes)/d.MB_maxbytes,4)*100 || '%' m_used_percentfrom  (select tablespace_name,sum(bytes/1024/1024) MB_current_Bytes,sum(maxbytes/1024/1024) MB_maxbytes from dba_data_files group by tablespace_name ) d,(select tablespace_name,sum(bytes/1024/1024) free_mb_bytes from dba_free_space group by tablespace_name) fwhere d.tablespace_name=f.tablespace_name order by c_free_percent ;

3.查看快照ID、查看快照设置信息、设置快照信息

select snap_id, begin_interval_time from sys.dba_hist_snapshot order by snap_id;select * from DBA_HIST_WR_CONTROL;begin

DBMS_WORKLOAD_REPOSITORY.MODIFY_SNAPSHOT_SETTINGS(retention =>43200,interval =>30, topnsql =>'MAXIMUM');

end;

/

cbcac6fc6ea463036073528fd723b720.png

4.统计信息清理

exec dbms_stats.purge_stats(systimestamp -11);

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Oraclesysaux表空间满了,需要进行清理或扩容操作。可以通过以下步骤进行处理: 1. 查看sysaux表空间的使用情况,确定是否需要扩容或清理。 2. 如果需要扩容,可以使用ALTER TABLESPACE命令进行扩容操作。 3. 如果需要清理,可以使用以下命令进行清理: a. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将表移动到其他表空间。 b. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将索引移动到其他表空间。 c. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将LOB对象移动到其他表空间。 d. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将对象移动到其他表空间。 e. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将对象移动到其他表空间。 f. 执行DBMS_SPACE_ADMIN.TABLESPACE_MOVER.PROCEDURE_MOVE_TABLESPACE将对象移动到其他表空间。 4. 清理完成后,可以再次查看sysaux表空间的使用情况,确保已经解决问题。 ### 回答2: Oracle数据库中的SYSAUX表空间是用于管理和存储系统级别的关键性能数据的空间。当该表空间满时,可能会导致数据库性能下降或无法正常工作。那么,我们该如何处理这种情况呢? 首先,我们可以通过查询V$SYSAUX_OCCUPANTS视图来确定哪些对象占用了SYSAUX表空间,并分析这些占用情况。通过该视图,我们可以得知哪些对象是占用空间比较大的,可以采取针对性的对其进行管理和优化,比如移除或重建该对象。 其次,我们可以通过执行自动维护任务来释放SYSAUX表空间中不必要的数据。Oracle自动在SYSAUX表空间中创建了若干个自动维护任务,这些任务定时执行清理、移除或归档等操作,可以释放出一定的空间。我们可以通过查询DBA_AUTOTASK_CLIENT视图来查看自动维护任务的设置情况,并可以修改或禁用不必要的任务来释放更多的空间。 另外,我们可以考虑对SYSAUX表空间进行扩展,以增加其存储容量。在扩展SYSAUX表空间时,我们需要确保数据文件存储在一个有效的磁盘位置,并要注意数据文件的分布和扩展方式。在扩展完毕后,我们需要重新分配表空间数据文件中的数据块,并重新计算表和索引的size,以保证数据结构的正确性和性能的稳定性。 综上所述,当SYSAUX表空间满了时,我们不必过于紧张,可以通过几种方式来解决问题。同时,我们也需要定期对数据库进行管理和优化,在日常运维过程中及时排查各种问题,以避免出现系统崩溃、数据丢失等问题。 ### 回答3: Oracle中的sysaux表空间是用来存储系统级别的常用数据和信息的,包括一些企业管理以及可选组件等等,通常占据大量的空间。当sysaux表空间满了时,会对数据库的正常运行造成重大影响,因此需要及时处理。 当sysaux表空间满了,我们可以采取以下措施: 1. 压缩sysaux表空间:对sysaux表空间中的数据进行压缩,从而减小该表空间的大小。可以使用Oracle提供的压缩工具或第三方工具来实现。 2. 重新分配sysaux表空间大小:通过修改数据库参数或使用Oracle提供的ALTER TABLESPACE命令进行重新分配表空间大小,以便更好地管理数据库空间,并解决sysaux表空间满的问题。 3. 清理和删除不必要的信息:可以通过查询sysaux表空间中的数据来确定哪些信息已过时或不再需要。然后,将这些信息清理并从sysaux表空间中删除,进一步减小表空间的大小。 总之,当Oracle中的sysaux表空间满了时,需要针对具体情况采取相应的措施来解决问题。在处理sysaux表空间的问题时,需慎重行事,以免影响整个数据库的正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值