ORACLE定时备份方案
ORACLE定时备份方案
采用ORACLE的EXP工具,实现ORACLE的备份;采用LINUX的服务crond实现定时功能。
1 编辑SH,实现备份功能
#vi oracle_backup.sh,输入以下内容
#!/bin/sh
ORACLE_BACKUP_HOME=/home/oracle/backup #定义ORACLE备份根目录
BACKUP_DATA=$ORACLE_BACKUP_HOME/day #定义ORACLE备份数据文件根目录
BACKUP_LOG=$BACKUP_DATA/log #定义ORACLE备份日志文件根目录
export ORACLE_BACKUP_HOME BACKUP_DATA BACKUP_LOG
DATA_FILE_NAME=data_backup #定义ORACLE备份日志文件名字前缀
LOG_FILE_NAME=log_backup #定义ORACLE备份日志文件名字前缀
export DATA_FILE_NAME LOG_FILE_NAME
BACKUP_AMOUNT=4 #定义ORACLE备份文件保存数量
export BACKUP_AMOUNT
datafile_amount=$(find $BACKUP_DATA -type f -name $DATA_FILE_NAME'_'*.dmp|wc -l) #查询ORACLE备份数据文件根目录下备份数据文件的数量
logfile_amount=$(find $BACKUP_LOG -type f -name $LOG_FILE_NAME'_'*.log|wc -l) #查询ORACLE备份日志文件根目录下备份日志文件的数量
del_datafile_count=$(($datafile_amount-$BACKUP_AMOUNT+1)); #计算需要删除ORACLE备份数据文件的数量
del_logfile_count=$(($datafile_amount-$BACKUP_AMOUNT+1)); #计算需要删除ORACLE备份日志文件的数量
if(($datafile_amount>=$BACKUP_AMOUNT));then
echo $BACKUP_DATA"路径下文件太多,正在清除备份数据文件"
for((i=0;i<$del_datafile_count;i++))
do
ls -t $BACKUP_DATA/$DATA_FILE_NAME'_'*.dmp| awk 'END{if(NR>=$BACKUP_AMOUNT){system("rm -rf "$NF);system("echo $BACKUP_DATA路径下,已删除文件"$NF)}}'#删除修改时间最早的一个数据文件
done
fi
if(($logfile_amount>=$BACKUP_AMOUNT));then
echo $BACKUP_LOG"路径下文件太多,正在清除备份日志文件"
for((i=0;i<$del_logfile_count;i++))
do
ls -t $BACKUP_LOG/$LOG_FILE_NAME'_'*.log| awk 'END{if(NR>=$BACKUP_AMOUNT){system("rm -rf "$NF);system("echo $BACKUP_LOG路径下,已删除文件"$NF)}}'#删除修改时间最早的一个日志文件
done
fi
rq=`date +"%Y%m%d%s"` #获取当前系统时间
su - oracle -c "/oracle/product/10.2.0/db_1/bin/exp sgedptwo/sgdb321@SGEMDP file=$BACKUP_DATA/$DATA_FILE_NAME'_'$rq.dmp log=$BACKUP_LOG/$LOG_FILE_NAME'_'$rq.log" #备份ORACLE数据库并记录日志
2 授予ORACLE用户使用备份目录权限
# mkdir /home/oracle/backup
# mkdir /home/oracle/backup/day
# mkdir /home/oracle/backup/day/log
#chown –R /home/oracle/backup
3 使用crond定制定时任务
#ps-ef|grep crond #查看crond服务是否开启
#service crond start|stop|restart #crond服务启动|停止|重启命令
#crontab –e,输入以下内容
0 0 * * * /oracle/oracle_backup.sh #每天00:00执行任务
0 0 1 * * /oracle/oracle_backup.sh #每月1号00:00执行任务
注释:
* * * * * command to be executed
- - - - -
| | | | |
| | | | ----- Day of week (0 - 6) (Sunday=0 )
| | | ------- Month (1 - 12)
| | --------- Day of month (1 - 31)
| ----------- Hour (0 - 23)
------------- Minute (0 - 59)
ORACLE定时备份方案的更多相关文章
- oracle定时备份与删除N天前备份文件
oracle定时备份数据库,以及删除7天前备份的数据. 1.创建存放备份目录: mkdir /home/oracle/data_backup mkdir /home/oracle/log_backup ...
- 搭建企业级全网数据定时备份方案[cron + rsync]
1.1.1. 服务端的配置[192.168.25.141] Rsync的端口是:873 man rsyncd.conf 查看帮助 Rsync是Redhat默认自带的,这里只是做了rsync服务器端的后 ...
- 全网数据定时备份方案[cron + rsync]
1.1.1. Rsync(远程同步)介绍 [Rsync等价scp cp rm共3个命令的和] 1.什么是Rsync: Linux下面开源的,很快,功能很多,可以实现全量及增量的本地或者远程数据同步 ...
- oracle定时备份
1.将如下代码复制到文本中,最后将文本后缀名称修改成XXX.bat 批处理文件: *********************************************************** ...
- Linux平台下Oracle定时备份数据
临时收到一个任务,就是在生产环境上定时备份oracle的数据.空闲时间搞了一下,真是一波三折,过程有点小郁闷,结果哈哈.现在进行总结一下 (1)新建一个shell脚本test.sh #!/bin/ba ...
- Oracle 定时备份数据库
[操作说明] 在前面的博客中,学习了如何Oracle如何备份数据库,实际开发过程中数据库应该每隔一段时间就要备份一次,所以我们就需要一个定时执行这个代码的功能,同时备份的文件可能进行一些处理,比如压缩 ...
- oracle 定时备份
第一步.bat脚本: @echo off echo 删除10天前的备分文件和日志 forfiles /p "z:/back" /m *.dmp /d -10 /c "cm ...
- Oracle定时备份数据库
1.导出命令:exp cpzxoa/cpzxoa@FENG file=D:\OracleBak\%date:~11,4%\jjmis_test.dmp log=D:\OracleBak\%date:~ ...
- Linux下oracle定时备份
1. 设置数据库空表可导出(oracel11g) 用PL/SQL登录数据库(或者其他工具) 执行: select 'alter table '||table_name||' allocate exte ...
随机推荐
- 微服务SpringCloud之注册中心Consul
Consul 介绍 Consul 是 HashiCorp 公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其它分布式服务注册与发现的方案,Consul 的方案更“一站式”,内置了服务注册与发 ...
- 基于python的scrapy环境搭建
0.1安装python软件 32位机的电脑安装python-3.6.3.exe 64位机的电脑安装python-3.6.3-amd64.exe 0.1.1 python环境搭建 执行安装程序 选择Ad ...
- html标签和css基础语法与浏览器兼容性等相关基础学习
<!-- table的使用 --> <h3>前端日常</h3> <form action="https://www.baidu.com"& ...
- jquery 取得select选中的值
1.取得选中的值 jQuery("#select").val();是取得选中的值 2.取得的文本 jQuery("#select option:selected&quo ...
- CSS3 transform属性
说明: transform 属性向元素应用 2D 或 3D 转换.该属性允许我们对元素进行移动(translate).旋转(rotate).缩放(scale)或倾斜(skew) transition属 ...
- ajax 请求前后处理
1. 介绍 通过 jQuery 提供的 ajaxSetup 方法,我们可以拦截页面上所有的 Ajax 请求响应(包括 $.ajax.$.post.$.get).这样我们可以对这些 Ajax 请求响应做 ...
- ArcGIS Server服务扩展SOE应用场景
何时需要使用SOE? 用自己的业务逻辑扩展ArcGIS Server • 分析超越了即拿即用的GP工具 • 功能超越了Esri Web APIS中包含的内容 • 通过其他方式细粒度的ArcObject ...
- 1. jQuery中的DOM操作
1)查找节点 通过jQuery选择器来完成 2)创建节点 创建元素节点:var newTd = $("<td></td>") 创建文本节点:在创建元素节点时 ...
- yii2 rules 规则
required : 必须值验证属性 [['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息']; #说明:CRequiredV ...
- SpringBoot-ElasticJob封装快速上手使用(分布式定时器)
elastic-job-spring-boot qq交流群:812321371 1 简介 Elastic-Job是一个分布式调度解决方案,由两个相互独立的子项目Elastic-Job-Lite和Ela ...