【转】基于Linux下 Oracle 备份策略(RMAN)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 文章转自:http://blog.csdn.net/robinson_0612/article/details/6454509 -- 基于Linux下 Oracle 备份策略(RMAN) 对于 Oracle 数据库的备份与恢复,尽管存在热备,冷备以及逻辑备份之外,使用最多的莫过于使用RMAN进行备份与恢复。

文章转自:http://blog.csdn.net/robinson_0612/article/details/6454509

-- 基于Linux下 Oracle 备份策略(RMAN)

对于 Oracle 数据库的备份与恢复,尽管存在热备,冷备以及逻辑备份之外,使用最多的莫过于使用RMAN进行备份与恢复。而制定RMAN备份策

略则是基于数据库丢失的容忍程度,即恢复策略来制定。在下面的备份策略中,给出的是一个通用的备份策略。在该备份策略中,使用了catalog方

式来保持备份脚本以及备份信息。在实际环境中应根据具体的情况对此进行相应的调整。

一、步骤

1.确认备份可用空间以及备份路径,根据需要创建相应文件夹

2.对于账户的连接创建一个connect.rcv,该文件包含连接到target 和catalog信息

3.创建通用的脚本用于删除过旧的备份和备份控制文件以及备份归档日志

global_del_obso --过旧备份

global_bkctl --备份控制文件

global_arch --备份归档日志

4.创建0,1,2级增量备份

这三个脚本中均包含第2步的3个脚本,先调用global_del,然后做增量备份,最后备份归档日志global_arch和控制文件global_bkctl

5.创建inc0.rcv,inc1.rcv,inc2.rcv

文件内容包含调用 @@/<dir>/connect.rcv以及run{execute global script scriptname;}exit;

6.编辑第4步的三个文件分别为inc0.sh,inc1.sh,inc2.sh

nohup $ORACLE_HOME/bin/rman cmdfile=/u03/bk/scripts/inc1.rcv log=/u03/bk/scripts/inc0.log append &

7.使用crontab制定备份计划

二、具体实现

演示环境:

系统: CentOS release 4.6 (Final) + Oracle 10g

目标数据库: austin

恢复目录数据库: david

备份目录: /u03/bk

连接脚本所在路径:/u03/bk/scripts

注:监听需要配置好且已启动

1.连接脚本

connect.rcv文件内容

1 connect catalog rman/rman@david;
2 connect target sys/oracle@austin;

catalog的通用脚本

1 rman cmdfile=/u03/bk/scripts/connect.rcv --(在rman中使用外部脚本)
2 rman catalog rman/rman@david target sys/oracle@austin --使用该脚本连接后创建通用脚本

2.建立通用脚本

--除不必要的备份

 1 RMAN> create global script global_del_obso comment 'A script for obsolete backup and delete it' {
 2 
 3 2> crosscheck archivelog all;
 4 
 5 3> delete noprompt expired archivelog all;
 6 
 7 4> allocate channel ch1 device type disk;
 8 
 9 5> delete noprompt obsolete recovery window of 7 days;
10 
11 6> release channel ch1;
12 
13 7> }

--备份控制文件脚本

 1 RMAN> create global script global_bkctl comment 'A script for backup control file'{
 2 
 3 2> allocate channel ch1 device type disk;
 4 
 5 3> backup as compressed backupset
 6 
 7 4> current controlfile reuse
 8 
 9 5> format='/u03/bk/backupctl.ctl'
10 
11 6> tag='bkctl';
12 
13 7> release channel ch1;
14 
15 8> }

--备份归档日志脚本

 1 RMAN> create global script global_arch comment "backup archivelog and then delete it" {
 2 
 3 2> allocate channel ch1 device type disk;
 4 
 5 3> allocate channel ch2 device type disk;
 6 
 7 4> sql "alter system archive log current"; --归档当前的联机日志
 8 
 9 5> set limit channel ch1 readrate=10240; --(读取速率10M)
10 
11 6> set limit channel ch1 kbytes=4096000; --(备份片的大小)
12 
13 7> backup as compressed backupset
14 
15 8> format='/u03/bk/arch_%d_%U'
16 
17 9> tag='bkarch'
18 
19 10> archivelog all delete input;
20 
21 11> release channel ch1;
22 
23 12> release channel ch2;
24 
25 13> }

--使用list看所有的已建立的全局脚本

list global script names; --(列出所有的脚本)

delete globals script script_name; --(除脚本)

RMAN> list global script names;

List of Stored Scripts in Recovery Catalog

Global Scripts

Script Name

Description

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

global_arch

backup archivelog and then delete it

global_bkctl

A script for backup control file

global_del_obso

A script for obsolete backup and delete it

3.创建0,1,2级增量备份脚本(注:每个脚本备份前会执行删除过旧的备份,脚本尾部会调用另外两个脚本来备份归档日志及控制文件)

--0增量备份

RMAN> create global script global_inc0 comment "backup database as incrmental level 0"{

2> execute global script global_del_obso;

3> allocate channel ch1 device type disk;

4> allocate channel ch2 device type disk;

5> set limit channel ch1 readrate=10240;

6> set limit channel ch1 kbytes=4096000;

7> set limit channel ch2 readrate=10240;

8> set limit channel ch2 kbytes=4096000;

9> backup as compressed backupset

10> incremental level 0 database

11> format='/u03/bk/inc0_%d_%U'

12> tag='inc0';

13> release channel ch1;

14> release channel ch2;

15> execute global script global_arch;

16> execute global script global_bkctl;

17> }

--1增量备份

RMAN> create global script global_inc1 comment "backup database as incrmental level 1"{

2> execute global script global_del_obso;

3> allocate channel ch1 device type disk;

4> allocate channel ch2 device type disk;

5> set limit channel ch1 readrate=10240;

6> set limit channel ch1 kbytes=4096000;

7> set limit channel ch2 readrate=10240;

8> set limit channel ch2 kbytes=4096000;

9> backup as compressed backupset

10> incremental level 1 database

11> format='/u03/bk/inc1_%d_%U'

12> tag='inc1';

13> release channel ch1;

14> release channel ch2;

15> execute global script global_arch;

16> execute global script global_bkctl;

17> }

--2增量备份

RMAN> create global script global_inc2 comment "backup database as incrmental level 2"{

2> execute global script global_del_obso;

3> allocate channel ch1 device type disk;

4> allocate channel ch2 device type disk;

5> set limit channel ch1 readrate=10240;

6> set limit channel ch1 kbytes=4096000;

7> set limit channel ch2 readrate=10240;

8> set limit channel ch2 kbytes=4096000;

9> backup as compressed backupset

10> incremental level 2 database

11> format='/u03/bk/inc2_%d_%U'

12> tag='inc2';

13> release channel ch1;

14> release channel ch2;

15> execute global script global_arch;

16> execute global script global_bkctl;

17> }

--在rman中检验rman的脚本global_inc0、global_inc1、global_inc2,因RMAN动检查,下面的句用来执行脚本(检验)

RMAN> run{

2> execute global script global_inc0;

3> execute global script global_inc1;

4> execute global script global_inc2;

5> }

--备份成情

list backupset summary;

4.建立shell脚本,让linux自动执行脚本

a. vi inc0.rcv,inc1.rcv ,inc2.rcv --注意不同的文件行不同的备份脚本

@@/u03/bk/scripts/connect.rcv --(rman下的脚本去用其他脚本用@@)(用脚本不需要分)

run{

execute global script gloal_inc0;

}

exit;

b. 编辑shell文件

vi inc0.sh

nohup $ORACLE_HOME/bin/rman cmdfile=/u03/bk/scripts/inc0.rcv log=/u03/bk/scripts/inc0.log append &

vi inc1.sh

nohup $ORACLE_HOME/bin/rman cmdfile=/u03/bk/scripts/inc1.rcv log=/u03/bk/scripts/inc0.log append &

vi inc2.sh

nohup $ORACLE_HOME/bin/rman cmdfile=/u03/bk/scripts/inc2.rcv log=/u03/bk/scripts/inc0.log append &

--注意:nohup&表示脚本放入后台

c.使用crontab建立一个备份计划

crontab -e

#min hour date mon day(星期) command

30 1 * * 0 /u03/bk/scripts/inc0.sh

30 1 * * 1 /u03/bk/scripts/inc2.sh

30 1 * * 2 /u03/bk/scripts/inc2.sh

30 1 * * 3 /u03/bk/scripts/inc2.sh

30 1 * * 4 /u03/bk/scripts/inc1.sh

30 1 * * 5 /u03/bk/scripts/inc2.sh

30 1 * * 6 /u03/bk/scripts/inc2.sh

d.重启crontab服务(如果没有启动)

# /sbin/service crond status --用于检查crontab 务状态

# /sbin/service crond stop //关闭服务

# /sbin/service crond restart //重启服务

# /sbin/service crond reload //重新载入配置

使crontab服务在系统启动的时候自动启动:

在/etc/rc.d/rc.local这个脚本的末尾加上:

/sbin/service crond start

e.从上面的备份策略来看,即

周日执行0级增量备份,相当于全备

周一,周二,周三执行2级增量备份

周四执行1级增量备份

周五,周六执行2级增量备份

f.编辑好的shell 脚本测试

chmod 755 *.sh --shell脚本加

测试脚本 例如./inc0.sh

三、总结

1.backup controlfile in each scripts tail (在脚本的尾部备份控制文件)

2.Delete obsolete backupset in each scripts threshold (删除旧的备份)

3.Switch logfile before backup database; (在数据库备份以前切换日志,备份联机重做日志)

4.Chmod u+x*.sh

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
21天前
|
存储 Linux 数据库
在Linux中,什么是快照备份?
在Linux中,什么是快照备份?
|
21天前
|
存储 Linux 数据安全/隐私保护
在Linux中,如何创建文件系统的备份?
在Linux中,如何创建文件系统的备份?
|
21天前
|
Linux 数据库
在Linux中,什么是冷备份和热备份?
在Linux中,什么是冷备份和热备份?
|
21天前
|
Unix Linux 测试技术
在Linux中,如何恢复备份的文件?
在Linux中,如何恢复备份的文件?
|
20天前
|
存储 监控 安全
在Linux中,如何进行系统备份?
在Linux中,如何进行系统备份?
|
22天前
|
SQL 关系型数据库 MySQL
在Linux中,如何备份和恢复MySQL数据库?
在Linux中,如何备份和恢复MySQL数据库?
|
22天前
|
存储 运维 监控
|
30天前
|
关系型数据库 数据库 PostgreSQL
Linux 环境手动备份postgresql数据库
【8月更文挑战第12天】在Docker环境中使用命令行工具对PostgreSQL数据库进行备份和恢复。首先,通过dockerexec进入容器,使用pg_dump进行数据库模式的备份,然后使用dockercp将备份文件导出。接着,若需导入数据到另一数据库,先将备份文件复制到目标容器,再利用psql命令进行数据恢复。整个过程需确保目标数据库无同名模式,以防止导入失败
24 3
|
19天前
|
存储 Linux 开发工具
在Linux中,如何备份某个用户的任务计划?
在Linux中,如何备份某个用户的任务计划?
|
20天前
|
Linux
在Linux中,如何进行备份或归档文件(tar 命令)?
在Linux中,如何进行备份或归档文件(tar 命令)?