文档章节

Linux下自动备份Oracle数据库并删除指定天数前的备份

DavidBao
 DavidBao
发布于 2015/06/03 10:05
字数 745
阅读 8
收藏 0
点赞 0
评论 0

说明:

Oracle数据库服务器

操作系统:CentOS

IP:192.168.0.198

端口:1521

SID:orcl

Oracle数据库版本:Oracle11gR2

具体操作:

1、root用户登录服务器

mkdir -p /backup/oracledata  #新建Oracle数据库备份目录

chown -R  oracle:oinstall /backup/oracledata -R #设置目录权限为oinstall用户组的oracle用户(用户oracle与用户组oinstall是在安装Oracle数据库时设置的)

系统运维  www.osyunwei.com  温馨提醒:qihang01原创内容 版权所有,转载请注明出处及原文链接

2、新建Oracle数据库备份脚本

vi /backup/oracledata/ordatabak.sh  #新建文件,输入以下代码

#!/bin/sh

export ORACLE_BASE=/data/oracle

export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1

export ORACLE_SID=orcl

export ORACLE_TERM=xterm

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

export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib

export LANG=C

export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

#以上代码为Oracle数据库运行账号oracle的系统环境变量设置,必须添加,否则crontab任务计划不能执行。

# oracle用户的系统环境变量路径:/home/oracle/.bash_profile

date=`date +%Y_%m_%d`   #获取系统当前日期时间

days=7  #设置删除7天之前的备份文件

orsid=`192.168.0.198:1521/orcl`  #Oracle数据库服务器IP、端口、SID

orowner=OSYUNWEI  #备份此用户下面的数据

bakuser=OSYUNWEI  #用此用户来执行备份,必须要有备份操作的权限

bakpass=OSYUNWEI  #执行备注的用户密码

bakdir=/backup/oracledata  #备份文件路径,需要提前创建好

bakdata=$orowner"_"$date.dmp #备份数据库名称

baklog=$orowner"_"$date.log #备份执行时候生成的日志文件名称

ordatabak=$orowner"_"$date.tar.gz #最后保存的Oracle数据库备份文件

cd $bakdir #进入备份目录

mkdir -p $orowner #按需要备份的Oracle用户创建目录

cd $orowner #进入目录

系统运维  www.osyunwei.com  温馨提醒:qihang01原创内容 版权所有,转载请注明出处及原文链接

exp $bakuser/$bakpass@$orsid grants=y owner=$orowner file=$bakdir/$orowner/$bakdata log=$bakdir/$orowner/$baklog #执行备份

tar -zcvf $ordatabak $bakdata  $baklog  #压缩备份文件和日志文件

find $bakdir/$orowner  -type f -name "*.log" -exec rm {} \; #删除备份文件

find $bakdir/$orowner  -type f -name "*.dmp" -exec rm {} \; #删除日志文件

find $bakdir/$orowner  -type f -name "*.tar.gz" -mtime +$days -exec rm -rf {} \;  #删除7天前的备份(注意:{} \中间有空格)

:wq #保存退出

chmod +x /backup/oracledata/ordatabak.sh   #添加脚本执行权限

3、vi /etc/crontab  #编辑系统任务计划,添加以下代码到最后一行

30 2 * * * oracle  /backup/oracledata/ordatabak.sh  #每天凌晨2点30分,以oracle用户执行ordatabak.sh备份文件

:wq! #保存退出

service crond restart #重启crond

每天凌晨2点30分,会自动备份数据库到/backup/oracledata/OSYUNWEI目录中,保存为.tar.gz压缩文件,并且删除7天前的备份,即只保留最近7天的数据。

备注:以上所有的代码都是在英文半角状态下输入。

至此,Linux下自动备份Oracle数据库并删除指定天数前的备份教程完成。

本文转载自:http://www.osyunwei.com/archives/5960.html

共有 人打赏支持
DavidBao
粉丝 113
博文 210
码字总数 126729
作品 0
昌平
K3CLOUD自动备份Oracle数据库并删除指定天数前的备份

系统环境:rhel 6.4+oracle 11.2.0.3.7+k3cloud6 主要参考下文,并根据实际情况做更改: http://www.osyunwei.com/archives/5960.html 1、root用户登录服务器 mkdir -p /u01/backup #新建Ora...

sfih ⋅ 2016/02/04 ⋅ 0

使用Grid Control快速部署Oracle物理Data Guard

使用Grid Control快速部署Oracle物理Data Guard [日期:2016-04-18] 来源:Linux社区 作者:secooler [字体:大 中 小] Grid Control(文中简称GC)是监控和管理数据库好帮手,同时也是一把双...

rootliu ⋅ 04/20 ⋅ 0

RMAN体系架构的常用组件

1.RMAN可执行程序 在Windows操作系统中为rman.exe,在Unix系统中为rman 程序所在位置:$ORACLE_HOME/bin a.进程与内存要求 更多的进程的需要 大池的分配 b.基本环境变量需求 ORACLESID,ORAC...

晨曦之光 ⋅ 2012/03/09 ⋅ 0

RMAN常用配置命令解释

1.RMAN的登陆退出命令: 方法一:$rman nocatalog 直接进入rman,以非 catalog 方式进行备份,也可以不要nocatalog rman〉 connect target / 连接到 target database 需要配置ORACLE的操作系统...

长平狐 ⋅ 2013/09/17 ⋅ 0

Confluence 6 用户提交的备份和恢复脚本

下面的代码是用户提交的,在使用的时候需要小心,因为 Atlassian 不提供这些代码的技术支持。如果你在使用或者修改这些代码的时候有任何问题,请粘贴到 post them to Atlassian Answers。 删...

honeymose ⋅ 06/18 ⋅ 0

如何正确删除Oracle 归档日志文件

当Oracle中的归档日志空间满时,则需要把它清空,否则将会影响数据库正常运行, 将无法正常登入ORACLE,需要删除一部分归档日志才能正常登入ORACLE。 一、首先删除归档日志物理文件,归档日志...

xiaocao13140 ⋅ 2017/10/09 ⋅ 0

管家婆MSDE数据库简易备份

管家婆软件自带备份功能,要么手动,要么只有第一次退出时备份,而且是指定的目录,总是不那么方便可靠。如果使用脚本加上Windows的任务计划,可以可靠而且方便的进行备份操作。 环境描述: ...

ray_deng ⋅ 2014/05/12 ⋅ 0

Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录

说明: 操作系统:CentOS Mongodb安装目录:/usr/local/mongodb Mongodb数据库存放目录:/home/data/mongodb/mongodb_data Mongodb日志存放目录:/home/data/mongodb/mongodb_log 实现目的:...

fastjrun ⋅ 2016/03/21 ⋅ 0

shell编程代码备忘

shell编程代码备忘 最近需要将服务器代码每天定时的拷贝到远程服务器中 所以需要写个脚本 写一个定时任务用到crontab 在crontab -e状态下编辑如下: 定时发布任务 最终上线版本 备份数据库...

陈小扁 ⋅ 2016/06/28 ⋅ 0

mysqldump备份指定mysql数据库脚本

前几天有朋友让帮忙写一个mysql数据备份脚本,于是就有了下文通过mysqldump命令备份数据库的脚本,贴出来跟大家交流,若有问题,请指正,谢谢。 实现功能: 1 备份指定的数据库 2 删除指定天...

xjxiaolei ⋅ 2017/07/19 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

R计算IV

参考文章 #读取文件 rawdata = read.csv("/path/to/csv/file",header=T) colnames(rawdata)[18] <- "y" //重命名因变量y #数据分区 训练集测试集 trainIdx <- sample(nrow(rawdata), round(......

火力全開 ⋅ 4分钟前 ⋅ 0

SQL老司机,在SQL中计算 array & map & json数据

摘要: 场景 通常,我们处理数据,一列数据类型要么是字符串,要么是数字,这些都是primitive类型的数据。 场景 通常,我们处理数据,一列数据类型要么是字符串,要么是数字,这些都是primi...

阿里云云栖社区 ⋅ 4分钟前 ⋅ 0

SQL老司机,在SQL中计算 array & map & json数据

摘要: 场景 通常,我们处理数据,一列数据类型要么是字符串,要么是数字,这些都是primitive类型的数据。 场景 通常,我们处理数据,一列数据类型要么是字符串,要么是数字,这些都是primi...

猫耳m ⋅ 15分钟前 ⋅ 0

关于ireport自定义变量类型为list的时候

自己摸石头过河,我真的应该去趟市中心图书馆,借本真正靠谱的教材 网上的东西,只有0.01%是有用的,还有0.99%是垃圾,剩下的99%是垃圾的复制品。。 哎!~ 问题是这样的,报表带sql,从db中获...

炑炑milina ⋅ 16分钟前 ⋅ 0

Spring mvc ContextLoaderListener 原理解析

对于熟悉Spring MVC功能,首先应从web.xml 开始,在web.xml 文件中我们需要配置一个监听器 ContextLoaderListener,如下。 <!-- 加载spring上下文信息,最主要的功能是解析applicationContex...

轨迹_ ⋅ 16分钟前 ⋅ 0

阿里云发布企业数字化及上云外包平台服务:阿里云众包平台

摘要: 阿里云正式发布旗下众包平台业务(网址:https://zhongbao.aliyun.com/),支持包括:网站定制开发,APP、电商系统等软件开发,商标、商品LOGO、VI、产品包装设计、营销推广、大数据人...

阿里云官方博客 ⋅ 18分钟前 ⋅ 0

Redis安装异常解决办法

官网地址:http://redis.io/ 官网下载地址:http://redis.io/download 1. 下载Redis源码(tar.gz),并上传到Linux 2. 解压缩包:tar zxvf redis-2.8.17.tar.gz 3. 进入解压缩后的文件夹:c...

slagga ⋅ 23分钟前 ⋅ 0

006. 深入JVM学习—年轻代

1. 年轻代图片 年轻代(Young)属于JVM堆内存空间的一个组成部分 所有使用关键字new新实例化的对象一定会在伊甸园区进行保存,而对于存活区保存的一定是已经在伊甸园区存在一段时间并且经过了...

影狼 ⋅ 23分钟前 ⋅ 0

如何成为一个合格的程序员

偶尔的,我会被人问道:如何成为一名优秀的程序员,更或者,如何成为一名程序员。每次人们问起,我都力图给出不同的答案。因此,我的答案是各种各样的。下面就是我认为的成为一名优秀的程序员...

柳猫 ⋅ 24分钟前 ⋅ 0

cups error_log日志暴增

日志内容 File \"/usr/lib/cups/notifier/dbus\" has insecure permissions 解决(未验证适用范围) sudo service cups stopsudo rm /etc/cups/subscriptions.conf*sudo rm -r /var/cac......

一介码夫_Hum ⋅ 28分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部