我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

本篇文章主要关于利用shell脚本实现对Oracle数据库定时进行备份操作,并删除指定天数前的备份文件,已经熟练掌握shell的大牛们请果断路过。本文如有雷同,纯属有意。

先做试验环境的介绍,再讲解具体步骤。本博客的第一篇文章,以后会尽量做得更好,写得不好得地方请多多包涵,欢迎提出各种建议,例如文章内容选择、操作步骤的详细程度等等。

环境:

操作系统:CentOS

        IP地址:192.168.1.2

        端口:1521

        SID:orcl

        Oracle版本:Oracle11g

具体步骤:

(1)root登录Oracle数据库服务器

#新建备份目录

mkdir /home/bak/orcl_data

        #设置目录权限,该用户和组是安装Oracle时设置的

chown -R oracle:oracle /home/bak/orcl_data

(2)创建备份脚本

#新建文件并输入代码,保存。脚本保存位置根据个人习惯。

        vim /usr/local/scripts/oracle_bak.sh

        #!/bin/sh

#添加Oracle运行用户oracle的系统环境变量,以便Crontab计划任务的执行

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

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

#获取日期和时间

        date=`date +%Y_%m_%d`

#设置删除15天前的备份

        days=15

#Oracle服务器IP、端口、SID

        orsid=`192.168.1.2:1521/orcl`

#备份此用户的数据

        orowner=osgnu

#执行备份的用户,必须有备份权限

        bak_user=osgnu

#执行备份的用户的密码

        bak_pass=osgnu

#备份的路径,提前创建好

        bak_dir=/home/bak/orcl_data

#备份数据库名称

        bak_data=$orowner"_"$date.dmp

#备份生成的日志文件的名称

        bak_log=$orowner"_"$date.log

#保存的Oracle数据库备份文件

        ordatatar=$orowner"_"$date.tar.gz  
#进入备份目录

        cd $bak_dir

#按需要备份的Oracle用户来创建相应目录

        mkdir -p $orowner

#进入目录

        cd $orowner

#执行备份

        exp $bak_user/$bak_pass@$orsid grants=y owner=$orowner file=$bak_dir/$orowner/$bak_data log=$bak_dir/$orowner/$bak_log

#压缩

        tar -zcvf $ordatatar $bak_data $bak_log

#删除备份文件

        find $bak_dir/$orowner -type f -name "*.dmp" -exec rm {} \;

#删除日志文件

        find $bak_dir/$orowner -type f -name "*.log" -exec rm {} \;

#删除15天前的备份

        find $bak_dir/$orowner -type f -name "*.tar.gz" -mtime +$days -exec rm {} \;

#保存退出

        :wq!

#添加执行权限

        chmod +x /usr/local/scripts/oracle_bak.sh

(3)编辑计划任务

        crontab -e或vim /etc/crontab然后添加以下内容

#每天凌晨1点30分以oracle用户的身份执行备份脚本

        30 1 * * * oracle /usr/local/scripts/oracle_bak.sh

#保存退出

        :wq!

#重启crond

        service crond restart

        自动备份oracle并删除指定天数前的备份已完成。

www.osgnu.com  温馨提醒:BruceZ原创内容 版权所有,转载请注明出处以及原文链接。

本文链接:www.osgnu.com/shell/1.html

转载请注明来源:OSGNU >> Linux自动备份Oracle并删除指定天数前的备份

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux实现定时备份MySQL数据库并删除30天前的备份文件

1. mysql5.6以上版本 2. 修改 /etc/my.cnf 文件# vim /etc/my.cnf [client] host=localhost user=你的数据库用户 password='你的数据库密码'3. 编写数据库脚本
2022-06-04

linux每天定时备份数据库并删除十天前数据详细步骤

每天定时备份数据库需要用到linux的定时任务,利用Linux的crondtab 命令。下面我们来看详细步骤: 一、写好shell脚本 mysqlbak.sh#!/bin/sh mysqldump -urhJxXSdEoot -pmysql
2022-06-04

怎么在linux中定时备份MySQL数据库并删除备份文件

怎么在linux中定时备份MySQL数据库并删除备份文件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一丶选择一个比较大位置来保存备份文件(创建文件就行)使用mkdir来创
2023-06-09

Shell脚本自动删除指定大小以上的备份文件

最近本地虚拟机的空间老是被备份给占满,为了偷懒不想自己天天登录上去清除,才写了这个自动清理脚本. 系统:centos 5.x 脚本内容: cat make_room.sh#!/bin/bash#size=`df -hP|grep /dev/
2022-06-04

Linux下怎么设置每天自动备份Oracle数据库

本篇内容介绍了“Linux下怎么设置每天自动备份Oracle数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一.先找到数据库的环境变量如
2023-06-27

怎么用批处理文件自动备份文件及文件夹并自动删除n天前的文件

这篇文章主要介绍怎么用批处理文件自动备份文件及文件夹并自动删除n天前的文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!下是备份的批处理,添加到"计划任务"中,设定时间自动运行 代码如下:@echo off rem
2023-06-08

如何实现Linux系统对网站数据定期自动备份与删除

本篇内容主要讲解“如何实现Linux系统对网站数据定期自动备份与删除”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现Linux系统对网站数据定期自动备份与删除”吧!需求是这样的,首先网站文
2023-06-13

Linux下如何实现MySQL数据库每天定时自动备份

在云计算的浪潮下,企业多将业务部署在云上。对于数据库中的数据,直接使用云数据库自带的备份功能实现备份,操作简单。但是云数据库备份数据的存储空间有限制,一旦超出存储量便自动关闭备份功能,运维人员往往也会忽略这个问题,如果这时遭遇系统故障,面临的就是数据丢失。 下
Linux下如何实现MySQL数据库每天定时自动备份
2016-01-07

怎么用Shell脚本自动删除指定大小以上的备份文件

这篇文章主要介绍“怎么用Shell脚本自动删除指定大小以上的备份文件”,在日常操作中,相信很多人在怎么用Shell脚本自动删除指定大小以上的备份文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shel
2023-06-09

Linux下设置每天自动备份数据库的方法

本文以Centos7.6系统与Oracle11g为例:一.先找到数据库的环境变量 如果是在root账户下,须先登录到数据库所在账户  su oracle cat ~/.bash_profileexport
2022-06-04

linux下自动备份MySQL数据并上传到FTP上的shell脚本

#!/bin/bash #Mysql autobackup shell # # #----------------set the mysql login parameters dbuser=root dbpasswd= dbserver=l
2022-06-04

编程热搜

目录