oracle 15124,DB_FILE_NAME_CONVERT参数导致ORA-15124:ASMfilename'..

RAC主库+DG单机环境中,一旦主备库之前有归档间隔,而这些归档可能由于种种原因被删除,如归档被清理了,备份集策略已经超出所需归档。也不用担心,可以按以下大致步骤做恢复: o 主库上做基于SCN的增量备份 o 将备份传输至备库 o 备库恢复增量备份 o 主库创

RAC主库+DG单机环境中,一旦主备库之前有归档间隔,而这些归档可能由于种种原因被删除,如归档被清理了,备份集策略已经超出所需归档。也不用担心,可以按以下大致步骤做恢复:

o 主库上做基于SCN的增量备份

o 将备份传输至备库

o 备库恢复增量备份

o 主库创建一个standby controlfile,并传输至备库

o 上一步生成的控制文件替换备库的控制文件

这几天遇到个非常奇怪的问题,主库创建standby controlfile时总是报错ORA-15124。这个问题也困扰了自己很多天。

都试过:

o 检查数据库的所有物理文件 asmcmd ls -l来查看

o 检查数据库数据字典 v$database.name / dba_data_files.file_name

o 在asmcmd debug模式下ls -l 查看文件

o 检查ASM的v$asm_file, v$asm_alias等等

o 对ORA-15124做10046和errorstack

o 检查DG备份等等

在创建standby controlfile依旧报错,错误如下:

SQL> show parameter conver;

NAME TYPE VALUE

———————————— ———– ——————————

db_file_name_convert string /data, +DATA/orcl/datafile

log_file_name_convert string /data, +DATA/orcl/onlinelog

(实际过程中,这两个参数如此配置是没有问题的…)

SQL> alter database create standby controlfile as ‘/tmp/a.ctl’ reuse;

alter database create standby controlfile as ‘/tmp/a.ctl’ reuse

*

ERROR at line 1:

ORA-15124: ASM file name ‘+data/odsptdb+DATAfile/system.259.862837403′ containsan invalid alias name

对以上加粗部分的字符串是哪里来的表示非常有疑问!

最终,检查DB_FILE_NAME_CONVERT参数的配置,并且做了以下试验:

SQL> alter session set db_file_name_convert=’/data’,’+abc‘;

————————————————————————/\\\\

Session altered.

SQL> alter database create standby controlfile as ‘/tmp/a.ctl’ reuse;

alter database create standby controlfile as ‘/tmp/a.ctl’ reuse

*

ERROR at line 1:

ORA-15124: ASM file name ‘+data/odsptdb+abcfile/system.259.862837403′ containsan invalid alias name

———————————————————-/\\\\\

SQL> alter session set db_file_name_convert=’/data’,’abc+abc’;

————————————————————————-\\

Session altered.

SQL> alter database create standby controlfile as ‘/tmp/a.ctl’ reuse;

alter database create standby controlfile as ‘/tmp/a.ctl’ reuse

*

ERROR at line 1:

ORA-15124: ASM file name ‘+data/odsptdbabc+abcfile/system.259.862837403′ contains an invalid alias name

————————————————————-\\

SQL> alter session set db_file_name_convert=’/data’,’abc‘;

Session altered.

SQL> alter database create standby controlfile as ‘/tmp/a.ctl’ reuse;

Database altered.

从以上几个试验可以看出,DB_FILE_NAME_CONVERT确实影响了standby controlfile的创建。而且串里不能包含“+” (即加号)

在以往的RAC+ASM中,印象里面DB_FILE_NAME_CONVERT和LOG_FILE_NAME_CONVERT参数是可以有“+” (即加号)的,这一次遇到了很奇怪的问题。计划找个时间窗口,将以上两个参数后半部分都改为”+DATA”,完全让ASM来管理。

特意在此记录一下。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值