當前位置:才華齋>IT認證>Oracle認證>

Oracle資料庫RMAN的自動備份指令碼簡介

Oracle認證 閱讀(1.63W)

各位同學知道Oracle資料庫RMAN如何自動備份指令碼嘛?下面小編為大家整理了關於Oracle資料庫RMAN的'自動備份指令碼文章,希望能為你提供幫助:

Oracle資料庫RMAN的自動備份指令碼簡介

  1、資料庫設定為歸檔方式

  2、資料庫的備份指令碼

db_full_ :資料庫全備指令碼

db_l0_ :資料庫0級備份指令碼

db_l1_ :資料庫1級備份指令碼

:資料FTP上傳指令碼

ftp_ :資料FTP清理指令碼

rman_ :資料備份主程式

  3、備份原理

每週1、3、6進行0級備份

每週日、2、4、5進行1級備份

備份檔案上傳到FTP服務

FTP伺服器每週清理一次,但是清理後將週六和週日的備份進行保留(和)

所有工作防暑crontab中自動執行備份

  4、備份目錄含義

arc :資料庫歸檔目錄

rmanbak :資料庫備份檔案的儲存目錄

rmanscripts :資料庫指令碼存放路徑

  5、FTP目錄

ftp上必須手動建立目錄

L0:

---1

---3

---6

L1:

---2

---4

---5

---0

rman_指令碼主程式

#!/bin/bash

#--------------------------------------------

# Oracle auto backup using rman

#

# author:songrh

# week:1,3,6 Level 0 backup

# 2,4,5,0 Level 1 backup

# Copyright by ChenLong Tec

#--------------------------------------------

#

#

export ORACLE_BASE=/u02/oracle

export ORACLE_HOME=/u02/oracle/product/9.2.4

export ORACLE_SID=PROD

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib:$ORACLE_HOME/network/jlib

export NLS_LANG=american_16GBK

export TNS_ADMIN=$ORACLE_HOME/network/admin

export ORA_NL33=$ORACLE_HOME/ocommon/nls/admin/data

export PATH=/bin:/usr/bin:/usr/sbin:$ORACLE_HOME/bin:$PATH

export PATH=$PATH:/opt/local/bin

#

SH_PATH=/u02/rmanscripts

ARC_PATH=/u02/arch

RMAN_BAK_PATH=/u02/rmanbak

#

#FULL_PATH=$RMAN_BAK_PATH/full

L0_PATH=$RMAN_BAK_PATH/L0

L1_PATH=$RMAN_BAK_PATH/L1

#

#DAY_TAG=`date "%Y-%m-%d"`

LOG_TAG=`date "%Y-%m-%d"`

#FIRST_DAY=`date %e`

WEEK=`date %w`

#WEEK=1

#

# FTP configure

IP="122.120.150.155"

FTPUSER="ftpbak"

FTPPASS="******"

FTPROOT0="L0"

FTPROOT1="L1"

#

DISK_USE=`df -k |sed -n '/u02/'p | awk '{print $5}' |sed 's/%//'`

####check path function

############

if [[ $DISK_USE -ge 90 ]]; then

rm -rf $L0_PATH/*

rm -rf $L1_PATH/*

fi

if [ "$WEEK" = "6" -o "$WEEK" = "3" -o "$WEEK" = "1" ]; then

if [ ! -d $L0_PATH ]; then

mkdir $L0_PATH

fi

if [ "$WEEK" = "1" ]; then

rm -rf $L0_PATH/*

rm -rf $L1_PATH/*

mkdir $L0_PATH/$WEEK

$SH_PATH/db_l0_ $L0_PATH/$WEEK

cd $L0_PATH/$WEEK

$SH_PATH/ftp_ $IP $FTPUSER $FTPPASS $FTPROOT0 $WEEK $WEEK_$LOG_

else

if [ ! -d $L0_PATH/$WEEK ]; then

mkdir $L0_PATH/$WEEK

$SH_PATH/db_l0_ $L0_PATH/$WEEK

cd $L0_PATH/$WEEK

$SH_PATH/ $IP $FTPUSER $FTPPASS $FTPROOT0 $WEEK $WEEK_$LOG_

else