ORACLE数据库 定时全量备份

Posted on   风行天下-2080  阅读(100)  评论(0编辑  收藏  举报

1、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

文章
————————————————
原文链接:https://blog.csdn.net/ldz_wolf/article/details/130010941

 

 

 

 

 

2、

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2022-05-25 django笔记--{% url %} 模板标签
2021-05-25 WireShark 常用过滤条件
2020-05-25 zabbix监控温度及风扇
2018-05-25 centos7环境下的Mysql5.7.22安装

随笔 - 618, 文章 - 0, 评论 - 6, 阅读 - 37万

Copyright © 2025 风行天下-2080
Powered by .NET 9.0 on Kubernetes

点击右上角即可分享
微信分享提示