如何做微信商城网站一级消防工程师考试
一、处理交易报错,查询发现是归档日志满导致的
ORA-00257: archiver error. Connect internal only, until freed.
二、查看归档日志大小
su - oracle
sqlplus / as sysdba
show parameter recover可查看到归档日志目录为:/u01/app/oracle/fast_recovery_area/******/archivelog
可以查看该目录的大小,对比数据库设置的日志空间,该目录大小不能大于数据库设置的空间。
select * from v$flash_recovery_area_usage;可以查看已使用的归档日志空间占比
三、扩大归档日志大小
alter system set db_recovery_file_dest_size=100G;
shutdown immediate;或者shutdown abort;
startup;
四、清理归档日志
扩大后还需设置定时计划清理归档日志,需要切换到oracle账号执行命令
rman target /
RMAN> crosscheck archivelog all;
RMAN> delete expired archivelog all;
RMAN> delete archivelog until time 'sysdate-3';
RMAN>delete force noprompt archivelog all completed before 'sysdate-1/48';
RMAN> delete archivelog sequence between 0 and 3100;
上面四条命令的解释:
1、第一条命令可以把无效的expired的archivelog标出来。
2、第二条命令直接全部删除过期的归档日志。
3、第三条命令直接删除三天前所有的归档日志。
4、第四条命令直接删除半小时前所有的归档日志。
5、按第1步查出的编号来删除
五、设置自动脚本
1、编写脚本
su - oracle //切换到oracle用户下执行操作
cd /u01/app
vim arcclear.sh
AIX服务器的清理脚本
#!/bin/sh
. /home/oracle/.profile
rman target / <
delete force noprompt archivelog all completed before 'sysdate-3';
#delete force noprompt archivelog all completed before 'sysdate-1/48';
exit;
EOF
chmod +x arcclear.sh
2、添加到计划任务
AIX服务器的定时任务
crontab -e
30 1 * * * sh /u01/app/arcclear.sh >> /u01/app/arcclear.log