Heim > Datenbank > MySQL-Tutorial > Oracle数据库中出现ORA-01157: 无法标识/锁定数据文件

Oracle数据库中出现ORA-01157: 无法标识/锁定数据文件

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-07 16:50:39
Original
1424 Leute haben es durchsucht

Oracle数据库中出现ORA-01157: 无法标识/锁定数据文件

环境:SLES 11 sp1 + RAC 11.2.0.3.7

马上要休假了,对数据库做了个检查,结果发现计费billingdb数据库的节点2出现如下错误:
 Fri Apr 25 21:51:13 2014
 Errors in file /Oracle/app/oracle/diag/rdbms/ispace/ispace2/trace/ispace2_m000_15002.trc:
 ORA-01157: 无法标识/锁定数据文件 54 - 请参阅 DBWR 跟踪文件
 ORA-01110: 数据文件 54: '/oracle/app/oracle/product/11.2.0/dbhome_1/dbs/DATADG'
 Fri Apr 25 22:01:14 2014
 Errors in file /oracle/app/oracle/diag/rdbms/ispace/ispace2/trace/ispace2_m000_30469.trc:
 ORA-01157: 无法标识/锁定数据文件 54 - 请参阅 DBWR 跟踪文件
 ORA-01110: 数据文件 54: '/oracle/app/oracle/product/11.2.0/dbhome_1/dbs/DATADG'
 

于是检查数据文件的状态,结果发现这个数据文件在节点2上查不到的。
 再到节点1检查时,,发现这个数据文件被创建在本地目录中了:
 TABLESPACE_NAME  FILE_ID FILE_NAME
      MB STATUS    AUT
 ----------------------- ---------- ----------------------------------------------------------- ---------- --------- ---
 SRPTSP  54 /oracle/app/oracle/product/11.2.0/dbhome_1/dbs/DATADG
    32500 AVAILABLE NO
 SRPTSP  55 +DATADG/ispace/datafile/srptsp.4718.845812309
    32500 AVAILABLE NO
 

郁闷,怎么会把数据文件创建在本地目录中呢?
 
经检查,发现是有一个新来的DBA创建数据文件时将"+DATADG"错误写成了"DATADG",相当于漏掉了"+",数据库根据OMF格式,默认将数据文件创建在本地目录的$ORACLE_HOME/dbs下面。更重要的是,刚刚好监控系统出现了故障,不然这个问题有就有警告了。幸好,这个是存放转存的历史数据,对业务没有产生影响,真是不幸中的万幸呀....
 

解决办法:
 再创建一个表空间,然后将54号数据文件上的所有对象move到新的表空间中,索引rebuild到新的表空间中,最后再:
 alter table xxxx move tablespace yyyyy;
 alter tablesapce SRPTSP drop datafile 54;
 再重新加数据文件到DATADG磁盘组中,将数据移回原表空间中。

--------------------------------------------------------------------------------

Linux-6-64下安装Oracle 12C笔记

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2

--------------------------------------------------------------------------------

本文永久更新链接地址:

linux

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage