首頁 > 資料庫 > mysql教程 > 数据库的逻辑备份和物理备份--非RMAN

数据库的逻辑备份和物理备份--非RMAN

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 17:13:54
原創
1522 人瀏覽過

数据库的逻辑备份和物理备份--非RMAN,不用借助其他工具,只要归档日志和物理备份就可以实现的备份

数据库的备份和恢复

常规而且重要,恢复得到理想状态

逻辑备份

利用EXP备份,从数据库提取写入操作系统文件

1.可以导出一个完整的数据库
2.也可以导出一个模式的文件或者一个定特定表
3.称为转储文件,默认为扩展名为.dmp
4. 表或用户模式从一个数库到另一个数据库,重新识别表
5.到处程序创建存储指定表,而不是数据库的逻辑备份

利用iMP导入成程序导入

导入数据,从*.dmp的数据导入删除或者丢失的数据。

不用借助其他工具,只要归档日志和物理备份就可以实现的备份

物理备份

 无论冷备份还是热备份,物理备份就是把数据库当中的数据文件做相应的拷贝,只

是冷备份是指脱机备份,
热被备份是指联机备份。
  
  1.冷备份,,脱机备份,就是要把数据库的服务器(服务)停掉
 1)SQL> shutdown immediate
 2)停掉数据库之后,数据目录oradata当中的相应的文件数据文件,日志文件,控制

文件,拷贝到一个地方
 3)拷贝当相关的路径下,比如c:/bak
 4)若果数据库的文件(目录oradata下)丢失或者损坏,就可以直接从备份中把全部物

理文件考进来,全部覆盖原来的文件。
   这样会造成子备份之日起所有新增数据的丢失。
 5)复制完成后,就可以重新启动数据库。
冷备份就是一个物理拷贝。

 
  2.热备份,正常情况下的备份
 1)不用关机,联机备份,一起正常运转。
 2)置于归档方式,查看归档方式
  archive log list
  
  目录redo01.log,redo02.log,redo03.log叫做联机日志,轮流写入。
热备份一定要置成归档方式,用归档来恢复。

 日志两类:联机日志和归档日志。
 路劲为 USE_BD_RECOVERY_FILE_DEST
 1、sql>alter system set log_archiver_start=true scop =spfile
 2、shutdown immediate 停掉数据库。
 3、startup mount,启动到有控制文件,但是不打开数据文件
 4、alter database archive 将数据库切换到归档方式
 5、alter database open
    总体上,将数据库的非归档方式和自动归档方式的禁用改成起作用

 6、archive log list 查看归档方式

 7、相关的备份工作可以开始
 假定当前的某个数据库进行一些备份工作
  SQL>alter tablespace tt begin backup;开始备份某个表
   Tablespace alter
    物理操作系统命令可以把tt.dbf拷贝到c:/temp。
   物理备份到某个路径
  SQL>alter tablespace  tt END BACKUP;
   Tablespace altered.
  SQL>alter system archive log current;将当前联机日志归档,
    system altered.
  SQL>alter system swich LOGFILE ;切换联机日志
  
  SQL>alter system swich LOGFILE ;
  SQL>shutdown immediate
  删除数据文件,再打开会出现一个错误
  startup 会提示问题。
  SQL>select * from v$recover_filel;会发现某个号文件找不到,就是  

 刚才删除的哪个文件
  SQL>alter database datafile 6 offline drop;
  SQL>alter database open
  把刚才备份到c:/temp的文件拷贝回来。
  SQL>select * from tt.deparment;不可以
  SQL>recover datafile 6;  指定auto
  SQL>alter database datafile 6 online;从归档的路径下。

总结:有效的赖以实现恢复的归档日志,做热备份,当数据库出现问题时候,客户数
恢复到指定的环节。归档的时候,做一个swich LOGFILE 。无论冷人备份也都还是物理备份
有效,就是 一个物理的拷贝,区别就是一个脱机,一个是联机。

当数据库中的控制文件丢掉一个或者几个的时候,我们通过什么办法弥补?


1、控制文件丢失,常规情况下可以备份控制文件。

 alter database backup controlfile to trace;备份路径
   可以查看 trace 的路径 show parameter dest/dump
  ps:11g的在/u01/app/Oracle/diag/rdbms/
     $ORACLE_SID/$ORACLE_SID/trace
 tarce中最新的文件,就是包含我们的控制文件备份信息,其中:
  1、注释信息不需要,
  2、需要从startup nomount开始的
  3、包括ALTER DATABASE OPEN;
  4、保存到专门的文件里,比如 ctl.sql
  5、删除控制文件。
  6、启动数据库后SQL>@ctl.sql,可以重建控制文件。

2、丢失日志文件,一个或者多个

 1、丢失日志文件,假定丢失了。
 2、SQL>recover database until cancel;基于取消的恢复数据库
 3、SQL>alter database open resetlogs;

更多Oracle相关信息见Oracle 专题页面 ?tid=12

linux

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板