登录  /  注册

Oracle数据库物理文件备份/恢复

php中文网
发布: 2016-06-07 15:53:43
原创
950人浏览过

之前也写过一篇类似的,虽然恢复Oracle数据库物理文件不成问题,但总感觉有不对的地方,后面才了解到,以前自己有存在误区的地方

之前也写过一篇类似的,虽然恢复Oracle数据库物理文件不成问题,,但总感觉有不对的地方,后面才了解到,以前自己有存在误区的地方,重新用此文方法简便得多。

环境:CentOS release 5.6 (Final)
   Oracle Database Release 11.2.0.1.0

1、解压压缩好的数据库文件到相应目录
[root@OATest oabak]# tar -jxvf testoa_20140702.tar.bz2

2、还原文件
[root@OATest temp]# su - oracle
[oracle@OATest /]$ export ORACLE_SID=testoa
[oracle@OATest /]$ sqlplus "/as sysdba";

OPEN_MODE
--------------------
READ WRITE
3、关闭数据库
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> exit

4、在sql模式下直接质数据库物理文件至相应的目录(先显示各类文件的路径所在,后拷贝到相应路径)
--显示控制文件

select name from v$controlfile;
--显示数据文件
select name from v$datafile;
--显示延续性的初始化参数文件(延续性:对初始化参数的在线修改可以直接作用到参数文件中)
show parameter spfile;
--显示日志文件
select member from v$logfile;
--orapw$ORACLE_SID密码文件:password file路径 在$ORACLE_HOME/dbs/orapw$ORACLE_SID    //跟备份关系不大,可以随时生成。

[oracle@OATest temp]$ sqlplus "/as sysdba";

host cp /usr/oabak/temp/control01.ctl /app/oracle/oradata/testoa/control01.ctl

host cp /usr/oabak/temp/control02.ctl /app/oracle/flash_recovery_area/testoa/control02.ctl
host cp /usr/oabak/temp/system01.dbf /app/oracle/oradata/testoa/system01.dbf
host cp /usr/oabak/temp/sysaux01.dbf /app/oracle/oradata/testoa/sysaux01.dbf
host cp /usr/oabak/temp/undotbs01.dbf /app/oracle/oradata/testoa/undotbs01.dbf
host cp /usr/oabak/temp/users01.dbf /app/oracle/oradata/testoa/users01.dbf
host cp /usr/oabak/temp/redo03.log /app/oracle/oradata/testoa/redo03.log
host cp /usr/oabak/temp/redo02.log /app/oracle/oradata/testoa/redo02.log
host cp /usr/oabak/temp/redo01.log /app/oracle/oradata/testoa/redo01.log
host cp /usr/oabak/temp/spfile${ORACLE_SID}.ora $ORACLE_HOME/dbs/
host cp /usr/oabak/temp/orapw${ORACLE_SID} $ORACLE_HOME/dbs/
--要删除临时文件, 重启的时候会自动创建temp01.dbf

若不删除临时文件,会出现下面的报错:
ORA-01187: cannot read from file  because it failed verification tests
ORA-01110: data file 201: '/app/oracle/oradata/testoa/temp01.dbf'
恢复文件时候没有删除,旧的临时表空间数据文件(300MB),无法创建新的临时表空间文件(500MB) ..所以一直报错

5、启动数据库
SQL> startup
ORACLE instance started.

Total System Global Area 4275781632 bytes
Fixed Size                  2220200 bytes
Variable Size            2113933144 bytes
Database Buffers        2147483648 bytes
Redo Buffers              12144640 bytes
Database mounted.
Database opened.
SQL> exit

6、修改用户密码
SQL> alter user oaadmin identified by oaadmin;
User altered.

7、解锁帐户
SQL> alter user oaadmin account unlock;
User altered.

上面第4步也可以利用一条命令直接处理:
select 'host cp /u03/backup/'||substr(name,(instr(name,'http://www.linuxidc.com/',-1)+1))||
  ' '||name from v$controlfile
 union all
 select 'host cp /u03/backup/'||substr(name,(instr(name,'http://www.linuxidc.com/',-1)+1))||
  ' '||name from v$controlfile
 union all
 select 'host cp /u03/backup/'||substr(member,(instr(member,'http://www.linuxidc.com/',-1)+1))
  ||' '||member from v$logfile
 union all
 select 'host cp /u03/backup/spfile${ORACLE_SID}.ora $ORACLE_HOME/dbs/'
  from dual
 union all
 select 'host cp /u03/backup/orapw${ORACLE_SID} $ORACLE_HOME/dbs/'
  from dual;

本文永久更新链接地址

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学