如何检查oracle的归档空间是否满了

 我来答
wintersun_zhao
推荐于2017-12-16 · 超过40用户采纳过TA的回答
知道小有建树答主
回答量:58
采纳率:0%
帮助的人:51.4万
展开全部
先查出当前数据库使用的归档目录是在哪,这个我昨天回答过一个问题。
http://zhidao.baidu.com/question/416031451
你可以参考一下。
然后,便可以到操作系统上,看归档目录所在的文件系统使用情况,如
一般的 unix 上,df -g 以 GB 为单位看,linux 上, df -h, 为以 GB 为单位看。
如果文件系统空间使用率达 90% 了,那就是快满了。
可以通过备份至磁带,再删除的方式进行。
如果是设置了 db_recovery_file_dest 及 db_recovery_file_dest_size 参数启用了 flash recovery area 后, 可能会由于该区域满而导致无法归档.
由于对 flash recovery area 的信息是记录于 rman repository 及控制文件中的, 因而, 仅是从磁盘删除旧的备份或是归档日志并不足够, 因为rman repository 及控制文件中仍持有该空间被使用的信息.
因而, 可增大 db_recovery_file_dest_size 的值, 或是从rman 中执行crosscheck archivelog all; 来标记相关归档日志已被删除, 再执行rman delete expired archivelog all; 来删除其记录.
最好的方式为rman backup archivelog until logseq <log#> delete all input;
这样一则进行了备份, 二则也删除了flash recovery area 中的空间, 并更新了控制文件.
同时,可使用
select * from v$RECOVERY_FILE_DEST;
来了解 recovery area 中允许的最大空间,已用的空间,可以被数据库自动回收的空间。
并进而使用
select file_type, PERCENT_SPACE_USED , PERCENT_SPACE_RECLAIMABLE, NUMBER_OF_FILES from v$RECOVERY_AREA_USAGE;
来了解 recovery area 中各类文件所占用的空间百分比。
如果 recovery area 是放在 asm 的 diskgroup 中的,还需要注意 相应的 diskgroup 中是否仍有空间。

11g 的 asm, 可在操作系统命令行,执行 asmcmd 进入命令行后
lsdg 命令,来查看 diskgroup 的总空间及剩余空间量。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式