2011年(93)
分类: Oracle
2011-12-02 14:11:50
第一步:把表空间Offline,把表空间的数据文件移动到D盘指定的目录。
第二步:修改表空间文件路径alter database rename file '旧文件路径' to '新文件路径';
第三步:把表空间Online,这样就可以了。
1.1 文件系统数据文件按迁移database must be open:
1.alter tablespace tbs read only;
2.alter tablespace tbs offline;
3.在offline时拷贝一份原文件,并命名为新文件名
4.alter tablespace tbs rename datafile'tbs_file_old.dbf' to 'tbs_file_new.dbf';
5.alter tablespace tbs online;
6.alter tablespace tbs read write;
7.alter database recover datafile'tbs_file_new.dbf';
1.2 裸设备数据文件迁移database must be mounted but not open:
1.为新的数据文件创建裸设备链接文件
2.starup mount;
3.alter database rename file 'tbs_file_old'to 'tbs_file_new';
4.alter database recover datafile'tbs_file_new';
5.alter database open;
2、系统紧急故障处理2.1控制文件损坏:控制文件记录了关于oracle的重要配置信息,如数据库名、字符集名字、各个数据文件、日志文件的位置等等信息。控制文件的损坏,会导致数据库异常关闭。一旦缺少控制文件,数据库也无法启动,这是一种比较严重的错误。
可以通过查询数据库的日志文件来定位损坏了的控制文件。日志文件位于$ORACLE_BASE/admin/bdump/alert_ORCL.ora.
2.1.1损坏单个控制文件:1. 确保数据库已经关闭,如果没有用下面的命令来关闭数据库:
svrmgrl>shutdown immediate;
2. 查看初始化文件$ORACLE_BASE/admin/pfile/initORCL.ora,确定所有控制文件的路径。
3. 用操作系统命令将其它正确的控制文件覆盖错误的控制文件。
4. 用下面的命令重新启动数据库
svrmgrl>startup;
5. 用适当的方法进行数据库全备份。
2.1.2损坏所有的控制文件:1. 确保数据库已经关闭,如果没有用下面的命令来关闭数据库:
svrmgrl>shutdown immediate;
2. 从相应的备份结果集中恢复最近的控制文件。对于没有采用带库备份的点可以直接从磁带上将最近的控制文件备份恢复到相应目录;对于采用带库备份的点用相应的rman脚本来恢复最近的控制文件。
3. 用下面的命令来创建产生数据库控制文件的脚本:
svrmgrl>startup mount;
svrmgrl>alter database backupcontrolfile to trace noresetlogs;
4. 修改第三步产生的trace文件,将其中关于创建控制文件的一部分语句拷贝出来并做些修改,使得它能够体现最新的数据库结构。假设产生的sql文件名字为createcontrol.sql.
注意:Trace文件的具体路径可以在执行完第3)步操作后查看$ORACLE_BASE/admin/bdump/alert_ORCL.ora文件来确定。
5. 用下面命令重新创建控制文件:
svrmgrl>shutdown abort;
svrmgrl>startup nomount;
svrmgrl>@createcontrol.sql;
6. 用适当的方法进行数据库全备份。
2.2重做日志文件损坏:数据库的所有增、删、改都会记录入重做日志。如果当前激活的重做日志文件损坏,会导致数据库异常关闭。非激活的重做日志最终也会因为日志切换变为激活的重做日志,所以损坏的非激活的重做日志最终也会导致数据库的异常终止。在ipas/mSwitch中每组重做日志只有一个成员,所以在下面的分析中只考虑重做日志组损坏的情况,而不考虑单个重做日志成员损坏的情况。
确定损坏的重做日志的位置及其状态:
1. 如果数据库处于可用状态:
select * from v$logfile;
svrmgrl>select * from v$log;
2. 如果数据库处于已经异常终止:
svrmlgr>startup mount;
svrmgrl>select * from v$logfile;
svrmgrl>select * from v$log;
其中,logfile的状态为INVALID表示这组日志文件出现已经损坏;log状态为Inactive:表示重做日志文件处于非激活状态;Active:表示重做日志文件处于激活状态;Current:表示是重做日志为当前正在使用的日志文件。
2.2.1损坏的日志文件处于非激活状态:1. 删除相应的日志组:
svrmgrl>alter database drop logfilegroup group_number;
2. 重新创建相应的日志组:
svrmgrl>alter database add log file group group_number (‘log_file_descritpion’,…) size log_file_size;
2.2.2损坏的日志文件处于激活状态且为非当前日志:1. 清除相应的日志组:
svrmgrl>alter database clear unarchivedlogfile group group_number;
2.2.3损坏的日志文件为当前活动日志文件:用命令清除相应的日志组:
svrmgrl>alter database clear unarchivedlogfile group group_number;
如果清除失败,则只能做基于时间点的不完全恢复。
打开数据库并且用适当的方法进行数据库全备份:
svrmgrl>alter database open;
2.3部分数据文件损坏:若损坏的数据文件属于非system表空间,则数据库仍然可以处于打开状态可以进行操作,只是损坏的数据文件不能访问。这时在数据库打开状态下可以单独对损坏的数据文件进行恢复。若是system表空间的数据文件损坏则数据库系统会异常终止。这时数据库只能以Mount方式打开,然后再对数据文件进行恢复。可以通过查看数据库日志文件来判断当前损坏的数据文件到底是否属于system表空间。
2.3.1非system表空间的数据文件损坏1. 确定损坏的文件名字:
svrmgrl>select name from v$datafilewhere status=‘INVALID’;
2. 将损坏的数据文件处于offline状态:
svrmgrl>alter database datafile‘datafile_name’ offline;
3. 从相应的备份结果集中恢复关于这个数据文件的最近的备份。对于没有采用带库备份的点可以直接从磁带上恢复;对于用带库备份的点用相应的rman脚本来恢复。
4. 恢复数据文件:
svrmgrl>alter database recover datafile‘file_name’;
5. 使数据库文件online:
svrmgrl>alter database datafile‘datafile_name’ online;
6. 用适当的方法进行数据库全备份。
2.3.2 system表空间的数据文件损坏:1. 以mount方式启动数据库
svrmgrl>startup mount;
2. 从相应的备份结果集中恢复关于这个数据文件的最近的备份。对于没有采用带库备份的点可以直接从磁带上恢复;对于用带库备份的点用相应的rman脚本来恢复。
3. 恢复system表空间:
svrmgrl>alter database recover datafile‘datafile_name’;
4. 打开数据库:
svrmgrl>alter database open;
5. 用适当的方法进行数据库全备份。
2.4表空间损坏:若非system表空间已经损坏,则数据库仍然可以处于打开状态可以进行操作,只是损坏的表空间不能访问。这样在数据库打开状态下可以单独对损坏的表空间进行恢复。若是system表空间损坏则数据库系统会异常终止。这时数据库只能以Mount方式打开,然后再对表空间进行恢复。可以通过查看数据库日志文件来判断当前损坏的表空间是否是system表空间。
2.4.1非system表空间损坏:1. 将损坏的表空间处于offline状态:
svrmgrl>alter tablespace‘tablespace_name’ offline;
2. 从相应的备份结果集中恢复关于这个表空间最近的备份。对于没有采用带库备份的点可以直接从磁带上恢复;对于用带库备份的点用相应的rman脚本来恢复。
3. 恢复表空间:
svrmgrl>alter database recovertablespace ‘tablespace_name’;
4. 使表空间online:
svrmgrl>alter tablespace‘tablespace_name’ online;
5. 用适当的方法进行数据库全备份。
2.4.2 system表空间损坏:1. 以mount方式启动数据库
svrmgrl>startup mount;
2. 从相应的备份结果集中恢复system表空间最近的备份。对于没有采用带库备份的点可以直接从磁带上恢复;对于用带库备份的点用相应的rman脚本来恢复。
3. 恢复system表空间:
svrmgrl>alter database recovertablespace system;
4. 打开数据库:
svrmgrl>alter database open;
5. 用适当的方法进行数据库全备份。
3、逻辑结构故障的处理方法:逻辑结构的故障一般指由于人为的误操作而导致重要数据丢失的情况。在这种情况下数据库物理结构是完整的也是一致的。对于这种情况采取对原来数据库的全恢复是不合适的,我们一般采用三种方法来恢复用户数据。
3.1采用exp/imp工具来恢复用户数据:如果丢失的数据存在一个以前用exp命令的备份,则可以才用这种方式。
1. 在数据库内创建一个临时用户:
svrmgrl>create user test_user identifiedby test;
svrmgrl>grant connect,resource totest_user;
2. 从以前exp命令备份的文件中把丢失数据的表按照用户方式倒入用户:
$imp system/manager file=export_file_name tables=(lost_data_table_name…)fromuser=lost_data_table_owner touser=test_user constraint=n;
3. 用相应的DML语句将丢失的数据从用户恢复到原用户。
4. 将测试用户删除:
svrmgrl>drop user test_user cascede;
3.2 采用logminer来恢复用户数据:Logminer是oracle提供的一个日志分析工具。它可以根据数据字典对在线联机日志、归档日志进行分析,从而可以获得数据库的各种DML操作的历史记录以及各种DML操作的回退信息。根据这些用户就可以将由于误操作而丢失的数据重新加入数据库内。
1. 确认数据库的utl_file_dir参数已经设置,如果没有则需要把这个参数加入oracle的初始化参数文件,然后重新启动数据库。下面例子中假设utl_file_dir=‘/opt/oracle/db01’;
2. 创建logminer所需要的数据字典信息
假设生成的数据字典文本文件为dict.ora:
svrmgrl> executedbms_logmnr_d.build(dictionary_filename=>'dict.ora',dictionary_location=>'/opt/oracle/db01');
3. 确定所需要分析的日志或者归档日志的范围。这可以根据用户误操作的时间来确定大概的日志范围。假设用户误操作时可能的日志文件为/opt/oracle/db02/oradata/ORCL/redo3.log和归档日志‘/opt/oracle/arch/orcl/orclarc_1_113.ora’。
4. 创建要分析的日志文件列表,按日志文件的先后顺序依次加入:
svrmgrl>executedbms_logmnr.add_logfile(logfilename=>'/opt/oracle/arch/orcl/orclarc_1_113.ora',options=>dbms_logmnr.NEW);
svrmgrl>executedbms_logmnr.add_logfile(logfilename=>'/opt/oracle/db02/oradata/ORCL/redo3.log',options=>dbms_logmnr.ADDFILE);
5. 开始日志分析,假设需要分析的时间在‘2003-06-2812:00:00’和‘2003-06-28 13:00:00’之间:
svrmgrl>executedbms_logmnr.start_logmnr(
dictfilename=>‘/opt/oracle/db01/dict.ora’,
starttime=>to_date(‘2003-06-28 12:00:00’,‘YYYY-MM-DD HH:MI:SS’),
endtime=>to_date(to_date(‘2003-06-2813:00:00’,‘YYYY-MM-DD HH:MI:SS’)
);
6. 获取分析结果:
svrmgrl>select operation,sql_redo,sql_undofrom v$logmnr_contents;
7. 根据分析结果修复数据。
8.结束logmnr:
svrmgrl>dbms_logmnr.end_logmnr;
9. 用适当的方法对原数据库进行数据库全备份。
4、数据文件丢失4.1、查看丢失的数据文件select file#from v$recover_file;
selectfile#,status,name from v$datafile order by 3;(status 为recovery)
4.2 将数据文件offline drop (noArchive)/offline(Archive)。
alter database datafile file# offline drop;
alter database datafile file# offline;
4.3 重建数据文件[可选] alter database create datafile file#.
4.4 恢复数据文件[可选] recover dafafile file#.(归档模式/非归档模式但是重做日志没有被覆盖)。
4.5 打开数据库。
alter database open;
4.6、删除丢失数据文件所在的表空间(该表空间仅有一个数据文件)[可选] drop tablespace tablespacename including contents and datafiles;