linux下expdp定时备份_Linux 自动备份 Oracle 数据库 Shell 脚本

本文介绍了如何在 Linux 上使用 expdp 实现 Oracle 数据库的自动备份。通过创建一个名为 oracle_backup.sh 的 Shell 脚本,设置好数据库连接信息和备份路径,脚本会每天凌晨1点执行一次,生成dmp文件并压缩,同时删除30天前的旧备份。文章详细展示了脚本内容和备份日志。
摘要由CSDN通过智能技术生成

我们之前也介绍过,如何在 Linux 备份 MySQL 。

作为一个后端开发人员,备份数据库是一个良好的习惯,虽然说数据库损坏或者数据丢失的概率很低,但是你不得不防,要不

2019-9-11 10:23:43

0

1.3k

我是备份在本机,所以我采用 Oracle 自带的 expdp 功能进行备份;如需要异地的,则需要针对以下脚本进行加工,这里不阐述

准备工作

本机具有 Oracle 的 expdp 导出功能

开始工作

创建 sh 脚本,命名为:oracle_backup.sh,以下是脚本

#!/bin/sh

export ORACLE_BASE=/mnt/u01/app/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1

export ORACLE_SID=orcl

export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin

export ORACLE_DIRECTORY=bakdir

# 备份目录

export DATA_DIR=/mnt/backup/bakdir

# 删除备份时间 30 天

export DEL_TIME=`date -d "30 days ago" +%Y%m%d`

# 备份时间

export BAKUP_TIME=`date +%Y%m%d%H%M%S`

# 字符编码

export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

# 账号

export db_user="test"

# 密码

export db_password="123456"

# db schemas

export db_schemas="data_schemas"

mkdir -p $DATA_DIR

echo "-- $(date +'%Y%m%d%H%M%S') 自动备份数据库并压缩开始 " >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始备份的文件名:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

echo "Bakup file path $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp"

expdp $db_user/$db_password@$ORACLE_SID schemas=$db_schemas directory=$ORACLE_DIRECTORY dumpfile=${ORACLE_SID}_${BAKUP_TIME}.dmp logfile=${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 备份成功:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始进行压缩:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp -> tar.gz" >> $DATA_DIR/BAK_LOG.txt;

cd $DATA_DIR && tar -czvf ${ORACLE_SID}_${BAKUP_TIME}.tar.gz ${ORACLE_SID}_${BAKUP_TIME}.dmp ${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 压缩成功:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.tar.gz" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始删除30天前备份记录文件:$DATA_DIR/${ORACLE_SID}_${DEL_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

rm -rf $DATA_DIR/${ORACLE_SID}_${DEL_TIME}*

echo "-- $(date +'%Y%m%d%H%M%S') 删除30天前备份记录文件:$DATA_DIR/${ORACLE_SID}_${DEL_TIME}.dmp 结束" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 开始删除当前备份记录文件:$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp" >> $DATA_DIR/BAK_LOG.txt;

rm -rf $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp $DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.log

echo "-- $(date +'%Y%m%d%H%M%S') 删除当前备份记录文件$DATA_DIR/${ORACLE_SID}_${BAKUP_TIME}.dmp 成功" >> $DATA_DIR/BAK_LOG.txt;

echo "------------------------------------------------------------------" >> $DATA_DIR/BAK_LOG.txt;

echo "-- $(date +'%Y%m%d%H%M%S') 自动备份数据库并压缩完毕 " >> $DATA_DIR/BAK_LOG.txt;

echo " " >> $DATA_DIR/BAK_LOG.txt;

echo " " >> $DATA_DIR/BAK_LOG.txt;

说明

上面的脚本是备份 30 天的数据库,我们可以每天导出一份 dmp 备份文件,文件的名称按 sid_当日日期 生成,然后进行打包压缩 tar.gz,最后再删除 30 天之前的数据库备份,然后删除当天备份的 dmp 以及 log;

赋予执行权限

chmod +x /mnt/backup/oracle_backup.sh

定时任务

在 Linux 中,我们利用 Crontab 来针对 oracle_backup.sh 脚本进行定时执行

crontab -e

添加一个定时任务,每天凌晨 1 点执行一次脚本,然后开始 Oracle 的备份

0 1 * * * /mnt/backup/oracle_backup.sh

备份日志 BAK_LOG.txt

-- 20200624010001 自动备份数据库并压缩开始

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

-- 20200624010001 开始备份的文件名:/mnt/backup/bakdir/orcl_20200624010001.dmp

-- 20200624010126 备份成功:/mnt/backup/bakdir/orcl_20200624010001.dmp

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

-- 20200624010126 开始进行压缩:/mnt/backup/bakdir/orcl_20200624010001.dmp -> tar.gz

-- 20200624010237 压缩成功:/mnt/backup/bakdir/orcl_20200624010001.tar.gz

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

-- 20200624010237 开始删除30天前备份记录文件:/mnt/backup/bakdir/orcl_20200525.dmp

-- 20200624010237 删除30天前备份记录文件:/mnt/backup/bakdir/orcl_20200525.dmp 结束

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

-- 20200624010237 开始删除当前备份记录文件:/mnt/backup/bakdir/orcl_20200624010001.dmp

-- 20200624010238 删除当前备份记录文件/mnt/backup/bakdir/orcl_20200624010001.dmp 成功

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

-- 20200624010238 自动备份数据库并压缩完毕

1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值