一次oracle数据库down事件(归档量较大,造成ASM空间满)

今天下午,小白我值班,领导接到电话说预生产库down,让我看了,小白我出大糗了

连上主机,ps -ef |grep smon

发现数据库实例不存在。

sqlplus / as sysdba

startup 之后能启动到mount状态。提示以下错。
ORA-03113: end-of-file on communication channel
小白一时不知道该如何做了。我是小白啊
后来领导看不下去自己去弄了。
 
 
大致流程如下
su - grid 
grid's password:
asmcmd
asmcmd>du                         这一步是看不出问题的
used_mb    mirror_used_mb
741939     741939
其实可以这样:
 
 
asmcmd>ls -ls
也可以在sql>下,select name,total_mb,free_mb from v$asm_diskgroup;
这个可以确认是asm磁盘满了导致的
接着是查看错误文档。
在sqlplus 下 查出路径
startup mount
SQL>show parameter background
然后cd /software/oracle/diag/rdbms/gdlthxzg/gdlthxzg/trace
tail -1000f alert_gdlthxzg.log
其中查看有关于归档的错误。
Errors in file /software/oracle/diag/rdbms/gdlthxzg/gdlthxzg/trace/gdlthxzg_ora_33816690.trc:
ORA-19816: WARNING: Files may exist in db_recovery_file_dest that are not known to database.


ARCH: Error 19504 Creating archive log file to '+DGSYSTEM'
Errors in file /software/oracle/diag/rdbms/gdlthxzg/gdlthxzg/trace/gdlthxzg_ora_33226774.trc:
 
 
接下来直接rman 删除归档
rman target /
delete noprompt archivelog all completed before 'trunc(sysdate)+12/24';
 
 
删除之后,
SQL>alter database open
数据库正常启动
 
 
为防止下次磁盘空间满造成这种事故
在aix下做定时删除任务
crontab -e
30 01 * * * /home/oracle/scripts/delarch.sh > /home/oracle/scripts/delarch.log

 
 
 
 
delarch.sh
export ORACLE_SID=bjschxsb1
export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1
export PATH=$ORACLE_HOME/bin:$PATH
/u01/app/oracle/product/11.2.0/db_1/bin/rman target / nocatalog log /u01/app/oracle/bakscripts/del_arch.log <
 
 
 
 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29863023/viewspace-1330190/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29863023/viewspace-1330190/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值