一、报错信息
前几天网站突然访问不了,并且报了如下错误:
ora-27101: shared memory realm does not exist
ora-01034: oracle not available 11g
ORA-24324: service handle not initialized
原因:由于数据库归档日志满了,不能继续往数据库里写数据。
二、查看归档日志大小
su - oracle
sqlplus / as sysdba
1
|
show parameter recover
|
可查看到归档日志目录为:/u01/app/oracle/fast_recovery_area/******/archivelog
可以查看该目录的大小,对比数据库设置的日志空间,该目录大小不能大于数据库设置的空间。
三、扩大归档日志大小
1
|
alter system
set
db_recovery_file_dest_size
=
100G
;
|
四、清理归档日志
扩大后还需设置定时计划清理归档日志,需要切换到oracle账号执行命令
rman target /
RMAN> crosscheck archivelog all;
RMAN> delete expired archivelog all;
RMAN> delete archivelog until time 'sysdate-3'
上面三条命令的解释:
1、第一条命令可以把无效的expired的archivelog标出来。
2、第二条命令直接全部删除过期的归档日志。
3、第三条命令直接删除三天前所有的归档日志。
参考:https://www.2cto.com/database/201308/235338.html
五、设置自动脚本
1、编写脚本
su - oracle //切换到oracle用户下执行操作
cd /u01/app
vim arcclear.sh
1
2
3
4
5
|
#!/usr/bin
rman target
/
<<EOF
delete force noprompt archivelog
all
completed before
'sysdate-3'
;
exit;
EOF
|
chmod +x arcclear.sh
2、添加到计划任务
crontab -e
1
|
30
1
*
*
*
sh
/
u01
/
app
/
arcclear.sh >>
/
u01
/
app
/
arcclear.log
|
service crond restart