Linux自动备份Oracle并删除指定天数前的备份
先做试验环境的介绍,再讲解具体步骤。本博客的第一篇文章,以后会尽量做得更好,写得不好得地方请多多包涵,欢迎提出各种建议,例如文章内容选择、操作步骤的详细程度等等。
环境:
操作系统: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并删除指定天数前的备份