oracle查找不到表空间,Oracle 一些表空间问题的处理

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 15:51   3268   0

一,SYSAUX 表空间不足

SYSAUX 表空间做为 SYSTEM 表空间的辅助表空间,主要存放 EM 相关的内容以及表统计信息,AWR快照,审计信息等,而如果 SYSAUX 表空间在默认条件下你如果不做任何配置,随着时间的推移,会膨胀的越来越大。

1、是什么占用了 sysaux 空间

select occupant_name, schema_name, occupant_desc, space_usage_kbytes

from v$sysaux_occupants

order by space_usage_kbytes desc

cc348561c3d392bf23603fce80f50a2a.png

可以看到是主要是 AWR 占用了空间。

2、清除 AWR

SQL> connect / as sysdba

SQL> @?/rdbms/admin/catnoawr.sql

SQL> @?/rdbms/admin/catawrtb.sql

3、查看表空间占用情况

SELECT B.TABLESPACE_NAME 表空间,

B.FILE_NAME 数据文件名,

B.BYTES / 1024 / 1024 大小M,

(B.BYTES - SUM(NVL(A.BYTES, 0))) / 1024 / 1024 已使用M,

SUBSTR((B.BYTES - SUM(NVL(A.BYTES, 0))) / (B.BYTES) * 100, 1, 5) || '%' 使用率

FROM DBA_FREE_SPACE A, DBA_DATA_FILES B

WHERE A.FILE_ID = B.FILE_ID

GROUP BY B.TABLESPACE_NAME, B.FILE_NAME, B.BYTES

ORDER BY B.TABLESPACE_NAME

二、USER 表空间不足

1、zabbix 报警表空间不足

739070cf49542860c075c93d23920da8.png

2、查看数据库表空间占用情况

SELECT B.TABLESPACE_NAME 表空间,

B.FILE_NAME 数据文件名,

B.BYTES / 1024 / 1024 大小M,

(B.BYTES - SUM(NVL(A.BYTES, 0))) / 1024 / 1024 已使用M,

SUBSTR((B.BYTES - SUM(NVL(A.BYTES, 0))) / (B.BYTES) * 100, 1, 5) || '%' 使用率

FROM DBA_FREE_SPACE A, DBA_DATA_FILES B

WHERE A.FILE_ID = B.FILE_ID

GROUP BY B.TABLESPACE_NAME, B.FILE_NAME, B.BYTES

ORDER BY B.TABLESPACE_NAME

aa1cc567e6990da7c014b095be1fdb0e.png

3、增加表空间

Alter tablespace USERS add datafile '/ordata/orcl/users17.dbf' size 20G;

三、SYSTEM 表空间不足

1、查看表空间使用率

SELECT B.TABLESPACE_NAME 表空间,

B.FILE_NAME 数据文件名,

B.BYTES / 1024 / 1024 大小M,

(B.BYTES - SUM(NVL(A.BYTES, 0))) / 1024 / 1024 已使用M,

SUBSTR((B.BYTES - SUM(NVL(A.BYTES, 0))) / (B.BYTES) * 100, 1, 5) || '%' 使用率

FROM DBA_FREE_SPACE A, DBA_DATA_FILES B

WHERE A.FILE_ID = B.FILE_ID

GROUP BY B.TABLESPACE_NAME, B.FILE_NAME, B.BYTES

ORDER BY B.TABLESPACE_NAME

2、查找占用大的对象

从dba_segments中找出占用SYSTEM表空间中排名前10位的大对象。

SELECT *

FROM (SELECT SEGMENT_NAME, SUM(BYTES) / 1024 / 1024 MB

FROM DBA_SEGMENTS

WHERE TABLESPACE_NAME = 'SYSTEM'

GROUP BY SEGMENT_NAME

ORDER BY 2 DESC)

WHERE ROWNUM < 10;

3、关闭审计(可选)

system表空间满了以后,对审计表进行清空,用新的审计表覆盖旧的审计表,如果用处不大,我们可以选择关闭审计功能,如下

sqlplus / nolog

connect sys/sys as sysdba

alter system set audit_trail='NONE' scope=spfile;

shutdown immediate;

startup;

4、清空审计日志

truncate table SYS.AUD$;

5、给表空间增加数据文件

alter tablespace system add datafile '/data/orcl/system02.dbf' size 2G;

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP