ORA-00257:归档程序错误,在释放之前仅限于内部连接

线上会员系统无法登录,查看user日志,发现报错:ORA-00257: 归档程序错误。在释放之前仅限于内部连接

原因分析:FLASH_RECOVERY_AREA 设置空间为60G。归档日志占满了FLASH_RECOVERY_AREA 的空间,就出现了以上的错误。

解决方案:

方法一:改变了FLASH_RECOVERY_AREA的大小

SQL>alter system setdb_recovery_file_dest_size=100G scope=both;

SQL> show parameter db_recovery_file_dest_size;

NAME    TYPE    VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest_size  big integer 100G

方法二:删除归档日志

2.1 查看归档日志所在位置
SQL> show parameter recover;

NAME    TYPE    VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest   string  /u01/app/oracle/rdbms/archivelog/
db_recovery_file_dest_size  big integer 100G
db_unrecoverable_scn_tracking   boolean TRUE
recovery_parallelism    integer 0

2.2 到具体的位置把归档文件删除
[oracle@kmb2b-db01 root]$ cd /u01/app/oracle/rdbms/archivelog/KMB2B/archivelog/
[oracle@kmb2b-db01 archivelog]$ rm -rf 2017_*

2.3 查看使用率 
SQL> select * from V$FLASH_RECOVERY_AREA_USAGE;

2.4 然后用户用rman进入把归档日志删除
>rman target/
>crosscheck archivelogall;
>delete expired archivelog all;
>exit

注:删除过期的归档或者删除指定时间之前的archivelog:
DELETE ARCHIVELOG ALL COMPLETED BEFORE'SYSDATE-7';(指定删除7天前的归档日志)

方法三:使用脚本自动化删除归档日志
[oracle@kmb2b-db01 init]$ cat oracle_del_archivelog.sh 
#!/bin/bash

export ORACLE_SID=kmb2b
export TERM=vt100
export ORACLE_BASE=/u01/app/oracle/rdbms
export NLS_DATE_FORMAT="yyyy-mm-dd hh24:mi:ss"
export ORACLE_DOC=$ORACLE_BASE/doc
export TMP=/tmp
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0
export PATH=$ORACLE_HOME/bin:$PATH
export NLS_LANG='SIMPLIFIED CHINESE_CHINA.AL32UTF8'

source /home/oracle/.bash_profile

$ORACLE_HOME/bin/rman target / <<EOF
crosscheck archivelog all;
delete force noprompt archivelog all completed before 'sysdate-30';
exit;
EOF
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ORA-00257错误是由于Oracle数据库的归档日志满了导致的。要解决这个问题,可以采取以下几个步骤: 1. 首先,确认归档日志的使用情况。你可以通过查询v$flash_recovery_area_usage视图来获取有关归档日志使用情况的信息。如果归档日志的使用量超过了可用空间的80%,则需要清理归档日志。 2. 清理归档日志。你可以使用RMAN工具或者手动删除过期的归档日志来释放空间。如果使用RMAN,可以运行以下命令:DELETE ARCHIVELOG UNTIL TIME 'sysdate-7' BACKED UP 1 TIMES TO DISK; 这个命令将删除一周前的已备份的归档日志。如果你使用手动删除归档日志,请确保你备份了这些归档日志,并且在删除之前先将它们标记为已备份。 3. 增加归档日志的存储空间。如果你发现归档日志频繁满了,可以考虑增加归档日志的存储空间。你可以通过修改参数LOG_ARCHIVE_DEST_n来指定归档日志的存储位置,或者增加归档日志的存储空间。 总结起来,解决ORA-00257错误的步骤包括确认归档日志的使用情况,清理过期的归档日志以释放空间,并且可以考虑增加归档日志的存储空间。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Oracle归档日志写满(ora-00257)了怎么办](https://download.csdn.net/download/weixin_38710781/12830263)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [ORA-00257: 归档程序错误 Oracle归档报错处理方式](https://blog.csdn.net/zl61347338/article/details/123202527)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [ORA-00257: Archiver error. Connect AS SYSDBA only until resolved错误解决](https://blog.csdn.net/Paulangsky/article/details/127518046)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东城绝神

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值