ORACLE数据库 定时全量备份

Oracle数据库备份:
1、创建备份目录;
2、编写备份脚本;
3、创建定时任务;

1、创建备份目录

创建oracle directory目录,创建用于备份的目录DMP_BAK,对应磁盘位置:/home/dbbak/dbdata/‘。意思是指:导致的文件存放在/home/dbbak/dbdata/目录下。

create or replace directory DMP_BAK as '/home/dbbak/dbdata/'; 

其他相关操作:

1、查询directory目录
select * from dba_directories;
2、创建或者修改 directory目录
create or replace directory 目录名称 as  '/存放目录路径' 
3、赋权 directory目录
grant read,write on directory 目录名称 to 用户名称;
4、删除directory目录
drop directory 目录名称;

2、编辑备份脚本:

编辑脚本:vim /home/dbbak/dbbackup.sh

#!/bin/bash
# su - oracle 
# echo $ORACLE_HOME
export ORACLE_BASE=/app
export ORACLE_HOME=/app/oracle/product/11.2.0/db_1
export ORACLE_SID=ORCL
export PATH=$ORACLE_HOME/bin:$PATH:$HOME/bin
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
# 当前日期
DATE=$(date +%Y%m%d)
# 7天之前日期,为的是删除7天之前的备份文件
DATE_RM=$(date -d "7 days ago" +%Y%m%d)
# 设置变量
export DIR=/home/dbbak/dbdata
echo $DIR
echo 'Oracle backup...'
# 开始执行数据备份
expdp longey/123456@orcl directory=DMP_BAK  dumpfile=$DATE'_DB.dmp' logfile=$DATE'_LOG.log' schemas=longey
echo 'Oracle backup successfully.'
echo '文件压缩'
# 将备份文件进行压缩
zip $DIR'/'$DATE'_DB.zip' $DIR'/'$DATE'_DB.dmp'
echo '文压缩成功'
echo 'remove...'
# 删除7天之前的备份文件和日志文件
rm -rf $DIR'/'$DATE'_DB.dmp' 
rm -rf $DIR'/'$DATE_RM'_DB.zip'
rm -rf $DIR'/'$DATE_RM'_LOG.log'

expdp 命令说明:
expdp 用户名/密码@数据库SID directory=目录名 dumpfile=导出文件名.dmp logfile=日志名.log schemas=要备份的用户名 。

3、定时任务

编辑定时任务

[root@localhost ~]#  crontab -e
# 每天零晨2点执行
0 2 * * * . /home/dbbak/dbbackup.sh 

查询当前定时任务:

[root@localhost ~]#  crontab -l 
# 每天零晨2点执行
0 2 * * * . /home/dbbak/dbbackup.sh 

完成以上配置后,数据库将在每天晚上执行全库备份。

备份与恢复数据库版本不一致时

1、导出指定版本号:

expdp test/test@test directory=DMP_BAK  dumpfile=2022122001_DB.dmp logfile=2022122001_LOG.log schemas=testVersion=11.2.0.1.0

2、导入时更换用户和表空间;导入时表空间名称默认时需要保持一致
原库用户名:test,目标库用户名:test2;
原库表空间:TEST,目标库表空间:TBS_TEST_DATA
原库临时表空间:TEST,目标库临时表空间:TBS_TEST_TEMP

impdp test2/test directory=DMP_BAK dumpfile=20230314_DB.dmp REMAP_SCHEMA=test:test2 remap_tablespace=TEST:TBS_TEST_DATA,TEMP:TBS_TEST_TEMP TRANSFORM=segment_attributes:n  table_exists_action=replace
  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
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
发出的红包

打赏作者

wolf犭良

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值