RAC本地数据文件迁移至ASM的方法(2)
一、 概述
目前在各个行业业务中存在大量的Oracle RAC环境,尤其对于中小型企业及一些管理不规范的环境中,对数据库的操作也就显得杂乱无章了,它不是核心系统,但有问题也够运维人员喝一壶的。下面说一个常见的问题,就是在RAC环境中,往往会遇到本地数据文件,也就是只能在一个节点访问,出现这样的状况,主要有两个原因,命名不规范,造成Oracle自动创建到DBS目录下,再个对RAC系统不了解,按照之前方式创建。那么在出现这个问题时怎么解决呢,下面我们简单学习一下。
二、操作过程
本次操作对象为非系统表空间,环境rhel6.3_x64+Oracle RAC11g
1、 RAC为归档模式,不停库,通过RMAN中copy命令,操作。
首先模拟环境:
SQL> alter tablespace FIRSOUL add datafile 'firsoul02.dbf' size 20m;
Tablespace altered. SQL> set lines 150 SQL> col file_name for a55 SQL> select file_name,file_id,ONLINE_STATUS,tablespace_name from dba_data_files;
FILE_NAME FILE_ID ONLINE_ TABLESPACE_NAME ------------------------------------------------------- ---------- ------- ------------------------------ +DATA/racdb/datafile/system.293.859438573 1 SYSTEM SYSTEM …………………… /oracle/app/oracle/product/11.2.0/dbs/firsoul02.dbf 7 ONLINE FIRSOUL +DATA/racdb/datafile/firsoul01.dbf 11 ONLINE FIRSOUL |
节点2,查看数据文件状态,信息
SQL> set lines 200 SQL> col file_name for a50 SQL> col tablespace_name for a10 SQL> select file_name,file_id,ONLINE_STATUS,tablespace_name from dba_data_files; ERROR: ORA-01157: cannot identify/lock data file 11 - see DBWR trace file ORA-01110: data file 7: '/oracle/app/oracle/product/11.2.0/dbs/firsoul02.dbf ' |
将本地数据文件OFFLINE,或可以将整个表空间OFFLINE
SQL> alter database datafile 7 offline; Database altered. |
通过RMAN CP命令拷贝数据文件
RMAN> copy datafile 7 to '+data';
Starting backup at 2015-06-11 03:54:55 using target database control file instead of recovery catalog allocated channel: ORA_DISK_1 channel ORA_DISK_1: SID=74 instance=racdb1 device type=DISK channel ORA_DISK_1: starting datafile copy input datafile file number=00007 name=/oracle/app/oracle/product/11.2.0/dbs/firsoul02.dbf output file name=+DATA/racdb/datafile/firsoul.259.882071697 tag=TAG20150611T035457 RECID=1 STAMP=882071699 channel ORA_DISK_1: datafile copy complete, elapsed time: 00:00:03 Finished backup at 2015-06-11 03:55:00
|
rename数据文件,并查看信息
SQL> alter database rename file '/oracle/app/oracle/product/11.2.0/dbs/firsoul02.dbf' to '+DATA/racdb/datafile/firsoul.259.882071697';
Database altered. Database altered. 2 ;
FILE_NAME FILE_ID ONLINE_ TABLESPACE_NAME ------------------------------------------------------- ---------- ------- ------------------------------ +DATA/racdb/datafile/system.293.859438573 1 SYSTEM SYSTEM +DATA/racdb/datafile/sysaux.288.859438589 2 ONLINE SYSAUX …………………… +DATA/racdb/datafile/firsoul01.dbf 11 RECOVER FIRSOUL |
我们可以看到,数据文件已移植到ASM中,但需要recover。
SQL> alter database datafile 7 online; alter database datafile 11 online * ERROR at line 1: ORA-01113: file 11 needs media recovery ORA-01110: data file 11: '+DATA/racdb/datafile/firsoul.259.882071697’ |
recover数据文件,再次将数据文件online
SQL> recover datafile 7; Media recovery complete. SQL> alter database datafile 7 online;
Database altered.
SQL> set lines 150 SQL> col file_name for a55 SQL> select file_name,file_id,ONLINE_STATUS,tablespace_name from dba_data_files;
FILE_NAME FILE_ID ONLINE_ TABLESPACE_NAME ------------------------------------------------------- ---------- ------- ------------------------------ +DATA/racdb/datafile/system.293.859438573 1 SYSTEM SYSTEM +DATA/racdb/datafile/sysaux.288.859438589 2 ONLINE SYSAUX ………… |
两个节点查看,都正常。
三、 总结
在Oracle RAC操作过程中,我们更需要严谨,对于非系统表空间可以不用启停数据库,不过需要查看数据库系统是是否归档模式,数据库版本,选择更合理的迁移方式。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29487349/viewspace-1696214/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29487349/viewspace-1696214/