今天下午,小白我值班,领导接到电话说预生产库down,让我看了,小白我出大糗了
连上主机,ps -ef |grep smon
发现数据库实例不存在。
sqlplus / as sysdba
startup 之后能启动到mount状态。提示以下错。
连上主机,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/