最后更新时间:2018/12/18

启用归档

--检查是否为归档

SQL> archive log list;

Database log mode              No Archive Mode

Automatic archival             Disabled

Archive destination            USE_DB_RECOVERY_FILE_DEST

Oldest online log sequence     1423

Current log sequence           1425

No Archive Mode 表示非归档模式

开归档:

alter database archivelog;

关归档:

alter database noarchivelog;

★ 开启归档步骤

--关库

shutdown immediate;

startup mount;

--配置归档路径

alter system set log_archive_dest_1='location=/home/oracle/arch';

--开启归档

alter database archivelog;

-- 确认开启了归档

SQL> archive log list;

Database log mode              Archive Mode

Automatic archival             Enabled

Archive destination            /home/oracle/arch

Oldest online log sequence     1423

Next log sequence to archive   1425

Current log sequence           1425

Rman备份

前置条件

做全量备份时,rman也会生成控制文件快照,只是这个控制文件快照生于备份集产生,不包含最后一次的备份信息,因而不能用于最后一次备份集恢复,解决办法有两种:

1.  开启控制文件自动备份

RMAN> configure snapshot controlfile name to '/home/oracle/product/11gr2/db_1/dbs/snapcf_orcl.f';

RMAN> configure controlfile autobackup on;

2.  全量备份后再备份控制文件

一般建议在全量备份后,备份控制文件、SPFILE 到指定路径,以备需要时可以恢复。

Rman自动备份相关脚本

startrmans.sh
#!/bin/bash

bak_dir=/home/oracle/rmans
# mkdir -p $bak_dir/{logs,data,init_files}
day=`date +%Y%m%d` tm=`date "+%Y%m%d %H:%M:%S"`
echo "$tm begin backup." echo "delete archive logs"
find /home/oracle/arch -name "*.dbf" -mtime +10 -exec rm -f {} \; rman target / nocatalog <<EOF >$bak_dir/logs/fullbak`date +%Y%m%d`.log
run{
allocate channel c1 device type disk; backup database
format "$bak_dir/data/fullback_%d_%T_%s"; backup current controlfile tag='bak_ctlfile' format="$bak_dir/init_files/ctl_file_%U_%T";
backup spfile tag='spfile' format='$bak_dir/init_files/ORCL_spfile_%U_%T'; release channel c1; } report obsolete;
delete noprompt obsolete; crosscheck backup;
delete noprompt expired backup;
list backup summary; exit;
EOF tm=`date "+%Y%m%d %H:%M:%S"`
echo "$tm end backup."

Rman备份恢复验证

在数据库运行过程,将数据文件、控制文件、redo文件移到别的目录,强行关掉数据库,再开数据库验证失败。

[oracle@localhost orcl]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Tue Dec 18 09:57:34 2018

Copyright (c) 1982, 2009, Oracle.  All rights reserved.

Connected to an idle instance.

SQL> startup

ORACLE instance started.

Total System Global Area 3273641984 bytes

Fixed Size                  2217792 bytes

Variable Size            2466252992 bytes

Database Buffers          788529152 bytes

Redo Buffers               16642048 bytes

ORA-00205: error in identifying control file, check alert log for more info

SQL> select open_mode from v$database;

select open_mode from v$database
                       *

ERROR at line 1:

ORA-01507: database not mounted

SQL> shutdown immediate;

ORA-01507: database not mounted

ORACLE instance shut down.

恢复操作

[oracle@localhost orcl]$ rman target /

Recovery Manager: Release 11.2.0.1.0 - Production on Tue Dec 18 10:15:25 2018

Copyright (c) 1982, 2009, Oracle and/or its affiliates.  All rights reserved.

connected to target database (not started)

RMAN> startup nomount;

Oracle instance started

Total System Global Area    3273641984 bytes

Fixed Size                     2217792 bytes

Variable Size               2466252992 bytes

Database Buffers             788529152 bytes

Redo Buffers                  16642048 bytes

RMAN> restore controlfile from '/home/oracle/rmans/init_files/ctl_file_11tl2p0u_1_1_20181218';

Starting restore at 18-DEC-18

using target database control file instead of recovery catalog

allocated channel: ORA_DISK_1

channel ORA_DISK_1: SID=958 device type=DISK

channel ORA_DISK_1: restoring control file

channel ORA_DISK_1: restore complete, elapsed time: 00:00:01

output file name=/home/oracle/oradata/orcl/control01.ctl

output file name=/home/oracle/flash_recovery_area/orcl/control02.ctl

Finished restore at 18-DEC-18

RMAN> alter database mount;

database mounted

released channel: ORA_DISK_1

RMAN> restore database;

Starting restore at 18-DEC-18

Starting implicit crosscheck backup at 18-DEC-18

allocated channel: ORA_DISK_1

channel ORA_DISK_1: SID=958 device type=DISK

Crosschecked 5 objects

Finished implicit crosscheck backup at 18-DEC-18

Starting implicit crosscheck copy at 18-DEC-18

using channel ORA_DISK_1

Finished implicit crosscheck copy at 18-DEC-18

searching for all files in the recovery area

cataloging files...

no files cataloged

using channel ORA_DISK_1

channel ORA_DISK_1: starting datafile backup set restore

channel ORA_DISK_1: specifying datafile(s) to restore from backup set

channel ORA_DISK_1: restoring datafile 00001 to /home/oracle/oradata/orcl/system01.dbf

channel ORA_DISK_1: restoring datafile 00002 to /home/oracle/oradata/orcl/sysaux01.dbf

channel ORA_DISK_1: restoring datafile 00003 to /home/oracle/oradata/orcl/undotbs01.dbf

channel ORA_DISK_1: restoring datafile 00004 to /home/oracle/oradata/orcl/users01.dbf

…………….省略部分……….

channel ORA_DISK_1: piece handle=/home/oracle/rmans/data/fullback_ORCL_20181218_31 tag=TAG20181218T093553

channel ORA_DISK_1: restored backup piece 1

channel ORA_DISK_1: restore complete, elapsed time: 00:02:15

Finished restore at 18-DEC-18

RMAN> recover database;

Starting recover at 18-DEC-18

using channel ORA_DISK_1

starting media recovery

unable to find archived log

archived log thread=1 sequence=1438

RMAN-00571: ===========================================================

RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============

RMAN-00571: ===========================================================

RMAN-03002: failure of recover command at 12/18/2018 10:32:34

RMAN-06054: media recovery requesting unknown archived log for thread 1 with sequence 1438 and starting SCN of 62636468

RMAN> alter database open resetlogs;

database opened

执行完不完全恢复完成。

周末测试后数据库恢复

先将数据库关闭,再直接用rman开启到 mount状态

RMAN> startup nomount;

Oracle instance started

Total System Global Area    3273641984 bytes

Fixed Size                     2217792 bytes

Variable Size               2466252992 bytes

Database Buffers             788529152 bytes

Redo Buffers                  16642048 bytes

RMAN> restore controlfile from '/home/oracle/rmans/init_files/ctl_file_11tl2p0u_1_1_20181218';

RMAN> alter database mount;

RMAN> list backup;   #查看最新备份数据文件SCN  62636468

BS Key  Type LV Size       Device Type Elapsed Time Completion Time

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

22      Full    3.28G      DISK        00:00:30     18-DEC-18     
         BP Key: 22   Status: AVAILABLE  Compressed: NO  Tag: TAG20181218T093553
         Piece Name: /home/oracle/rmans/data/fullback_ORCL_20181218_31
   List of Datafiles in backup set 22
   File LV Type Ckp SCN    Ckp Time  Name
   ---- -- ---- ---------- --------- ----
   1       Full 62636468   18-DEC-18 /home/oracle/oradata/orcl/system01.dbf
   2       Full 62636468   18-DEC-18 /home/oracle/oradata/orcl/sysaux01.dbf
   3       Full 62636468   18-DEC-18 /home/oracle/oradata/orcl/undotbs01.dbf

RMAN>run

{set until scn 62636468;

restore database;

recover database;

}

rman备份集清理

手工删除了备份集磁盘文件后,使用crosscheck backupset  检查会提示EXPIRED.需要使用 delete expired backupset;  删除对应记录。

RMAN> crosscheck backupset ;

allocated channel: ORA_DISK_1

channel ORA_DISK_1: SID=776 device type=DISK

crosschecked backup piece: found to be 'EXPIRED'

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_2 RECID=1 STAMP=995105790

crosschecked backup piece: found to be 'EXPIRED'

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_3 RECID=2 STAMP=995107713

crosschecked backup piece: found to be 'EXPIRED'

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_4 RECID=3 STAMP=995107750

Crosschecked 3 objects

RMAN>  delete expired backupset;

using channel ORA_DISK_1

List of Backup Pieces

BP Key  BS Key  Pc# Cp# Status      Device Type Piece Name

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

1       1       1   1   EXPIRED     DISK        /home/oracle/rmans/data/fullback_ORCL_20181217_2

2       2       1   1   EXPIRED     DISK        /home/oracle/rmans/data/fullback_ORCL_20181217_3

3       3       1   1   EXPIRED     DISK        /home/oracle/rmans/data/fullback_ORCL_20181217_4

Do you really want to delete the above objects (enter YES or NO)? YES

deleted backup piece

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_2 RECID=1 STAMP=995105790

deleted backup piece

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_3 RECID=2 STAMP=995107713

deleted backup piece

backup piece handle=/home/oracle/rmans/data/fullback_ORCL_20181217_4 RECID=3 STAMP=995107750

Deleted 3 EXPIRED objects

常用命令

--查看所有配置

RMAN> show all;

--查看备份集

list backup summary

-- 列出不符合备份策略的备份记录

report obsolete

--查看备份策略

RMAN> show RETENTION POLICY;

RMAN configuration parameters for database with db_unique_name ORCL are:

CONFIGURE RETENTION POLICY TO REDUNDANCY 1; # default

EXPIRED和OBSOLETE的区别

EXPIRED状态的产生,与crosscheck命令是密切相关的,RMAN通过crosscheck命令检查备份是否存在于备份介质上,如果不存在,则状态由AVAILABLE改为EXPIRED。即一般是硬盘上被人工删除掉的文件会显示为EXPIRED。

而OBSOLETE是指该超过保留策略的备份,标记为obsolete。如已有一个全量备份,之前的备份被标识为obsolete。

recover database until cancel和 recover database区别

recover database until cancel用于不完全恢复,可以一步一步的跳也就是一个一个归档的应用,也可以AUTO全部应用,当然也可以在恢复完某个archivelog后cancel退出,但是他不会恢复current logfile如果需要恢复current logfile需要自己指定。

recover database 用于完全恢复,全部一起应用,包含current logfile,但是如果没有current logfile当然也会报错。

Rman备份及不完全恢复操作的更多相关文章

  1. Oracle RMAN 备份及不完全恢复(删除archievelog)

    RMAN备份命令 backup Database format='/home/oracle/backup/bak_full_%U_%T' tag='bak_full'; sql 'alter syst ...

  2. Linux服务器下对Oracle作Rman备份

    由于工作需要,最近要对几台Linux系统下的Oracle数据库进行Rman备份,就在操作的同时,整理了一下,方便今后作为资料进行查阅. ------------------------Linux服务器 ...

  3. Oracle RMAN备份恢复指导书

    目 录 1 目的与范围... 1 2 术语和定义... 1 3 角色和职责... 2 4 使用RMAN备份数据库... 2 4.1.1 检查数据库模式... 2 4.1.2 连接到target数据库. ...

  4. RMAN 备份详解

    一.数据库备份与RMAN备份的概念 1.数据库完全备份:按归档模式分为归档和非归档 归档模式 打开状态,属于非一致性备份        关闭状态,可以分为一致性和非一致性 非归档模式 打开状态,非一致 ...

  5. Oracle RMAN备份与还原

    RMAN在数据库服务器的帮助下实现数据库文件.控制文件.数据库文件与控制文件的映像副本.归档日志文件.数据库服务器参数文件的备份. RMAN的特点: (1) 支持增量备份:传统的exp与expdp备份 ...

  6. ORACLE RMAN备份及还原(转)

    RMAN可以进行增量备份:数据库,表空间,数据文件 只有使用过的block可以被备份成backup set 表空间与数据文件对应关系:dba_data_files / v$datafile_heade ...

  7. RMAN备份(转)

    原文:http://blog.csdn.net/leshami/article/details/6032739 一.数据库备份与RMAN备份的概念 1.数据库完全备份:按归档模式分为归档和非归档 归档 ...

  8. Oracle之RMAN备份及还原

    RMAN可以进行增量备份:数据库,表空间,数据文件 只有使用过的block可以被备份成backup set 表空间与数据文件对应关系:dba_data_files / v$datafile_heade ...

  9. rman 备份并异机恢复

    1.RMAN 备份脚本 RUN { CONFIGURE RETENTION POLICY DAYS; CONFIGURE CONTROLFILE AUTOBACKUP ON; CONFIGURE CO ...

随机推荐

  1. R学习小计

    安装R扩展包:install.packages("FKF")http://www.douban.com/note/243004605/1.输入数据 l读入有分隔符数据:A<- ...

  2. Js中遇到的坑点汇总

    一.Android 手机下输入框获取焦点时, 输入法挡住输入框的 bug 解决思路: 1.去掉overflow属性 2. Android 手机下, input 或 textarea 元素聚焦时, 主动 ...

  3. iptables 简单介绍及应用 Linux防火墙

    iptables 即 Linux防火墙 的简单介绍及使用 iptables生效位置如下图: 其中, 网络防火墙也可以使用一台启用了iptables的Linux主机代替; 路由器或集线器等设施在拓扑中省 ...

  4. (五)Redux入门

    1 Redux概念简述 flux推出的时候有一些缺点.比如store可以存在多个,不是特别好用 于是逐渐进化为了redux. 2 Redux的工作流程 拿借书作举例: action creators是 ...

  5. 微信小程序优化

    setData setData 是小程序开发中使用最频繁的接口,也是最容易引发性能问题的接口.在介绍常见的错误用法前,先简单介绍一下 setData 背后的工作原理. 工作原理 小程序的视图层目前使用 ...

  6. HTTP 文件共享服务器工具 - chfs

    CuteHttpFileServer/chfs是一个免费的.HTTP协议的文件共享服务器,使用浏览器可以快速访问.它具有以下特点: 单个文件,整个软件只有一个可执行程序,无配置文件等其他文件 跨平台运 ...

  7. pandas 7 合并 merge 水平合并,数据会变宽

    pd.merge( df1, df2, on=['key1', 'key2'], left_index=True, right_index=True, how=['left', 'right', 'o ...

  8. Adobe AIR and Flex - 保存序列化对象文件(译)

    创建任何桌面应用程序几乎总是需要在本地存储数据,通过Adobe AIR我们有几下面几个选择,一个是我们能够使用内置的 SQLite 数据库支持,对于少量的数据这是大材小用了.另外一个选择是我们通过把数 ...

  9. C语言过程活动记录

    C 语言自动提供的服务之一就是跟踪调用链——哪些函数调用了哪些函数,当下一个return语句执行后,控制将返回何处等.解决这个问题的经典机制是堆栈中的活动记录. 当每个函数被调用时,都会产生一个过程记 ...

  10. root用户无法切换到cdh的hive账号上

    在/etc/passwd中看到hive账号是登录的终端是/bin/false,而正常的用户配置的都是/bin/bash,因此在root账号su到hive也是没有用的 hive:x:111:111:Hi ...