专栏首页乐沙弥的世界Linux/Unix shell 自动 FTP 备份档案

Linux/Unix shell 自动 FTP 备份档案

       使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等。本文给出Linux 下使用 shell 脚本来实现自动FTP备份档案。

       Linux Shell以及导入导出的相关参考:

  • Linux/Unix shell 脚本中调用SQL,RMAN脚本
  • Linux/Unix shell sql 之间传递变量
  • Linux/Unix shell 调用 PL/SQL
  • Linux/Unix shell 监控Oracle实例(monitor instance)
  • Linux/Unix shell 监控Oracle监听器(monitor listener)
  • Linux/Unix shell 监控Oracle告警日志(monitor alter log file)
  • 数据泵 EXPDP 导出工具的使用
  • 数据泵IMPDP 导入工具的使用
  • 导入导出 Oracle 分区表数据
  • expdp impdp中 exclude/include 的使用
  • 使用 Oracle Datapump API 实现数据导出

1、Linux/Unix shell 自动 FTP 脚本

robin@SZDB:~/dba_scripts/custom/bin> more auto_ftp_dump.sh
# +---------------------------------------------------+
# +    Filename: ftp_dump_auto.sh                     |
# +    Desc: Ftp the dump file automatically          |
# +    Usage:                                         |
# +            ./auto_ftp_dump.sh $ORACLE_SID         |
# +    Author: Robinson                               |
# +    Blog  : http://blog.csdn.net.robinson_0612     |
# +---------------------------------------------------+
#
#!/bin/bash
#
# -----------------------------
#  Define environment variable
# -----------------------------
#

if [ -f ~/.bash_profile ];
then
. ~/.bash_profile
fi

# --------------------------
#   Check SID
# --------------------------

if [ -z "${1}" ];then
    echo "Usage: "
    echo "      `basename $0` ORACLE_SID"
    exit 1
fi

ORACLE_SID=${1};       export ORACLE_SID
TARGET_SID=SY0755BK
TIMESTAMP=`date +%Y%m%d%H%M`;
DT=`date +%Y%m%d`;
RETENTION=1

DUMP_DIR=/u01/oracle/admin/SY0755/BNR/dump
DUMP_FILE=${DUMP_DIR}/EXP_${ORACLE_SID}_${DT}.dmp
LAST_EXP_DUMP_LOG=${DUMP_DIR}/EXP_${ORACLE_SID}_${DT}.log

FTP_LOG=${DUMP_DIR}/ftp_${ORACLE_SID}_${TIMESTAMP}.log
FTP_ERR_LOG=${DUMP_DIR}/ftp_${ORACLE_SID}_${TIMESTAMP}_err.log

date >>${FTP_LOG}
echo "FTP source : ${ORACLE_SID}" >>${FTP_LOG}
echo "FTP target : ${TARGET_SID}" >>${FTP_LOG}
echo "Staring tar the dump file " >>${FTP_LOG}

# -------------------------
#  tar the dump file
# -------------------------

if [ -s "${DUMP_FILE}" ] && [ -s "${LAST_EXP_DUMP_LOG}" ];then
    cd ${DUMP_DIR}
    tar -czvf EXP_${ORACLE_SID}_${DT}.tar.gz ./EXP_${ORACLE_SID}_${DT}.???
else
    echo "Dump file does not exist for ${ORACLE_SID}" >>${FTP_LOG}
    MAIL_SUB="Dump files were not found for ${ORACLE_SID} on `hostname` before start to tar the dump file"
    mail -s $MAIL_SUB dba@trade.com <${FTP_LOG}
    exit 1
fi

# --------------------------------------------
#  config ftp parameter and ftp the dump file
# --------------------------------------------

if [ ! -s "${DUMP_DIR}/EXP_${ORACLE_SID}_${DT}.tar.gz" ];then
    echo "The dump files were not compressed before start ftp">>${FTP_LOG}
    MAIL_SUB=" The dump files were not compressed for ${ORACLE_SID} on `hostname` before start ftp, exit!"
    mail -s $MAIL_SUB dba@trade.com <${FTP_LOG}
    exit 1
fi

echo "Start copy tar file to ${TARGET_SID} ...." >>${FTP_LOG}
echo "--------------------------------------------------">>${FTP_LOG}

FTP_SRV=10.200.48.21
FTP_USR=oracle
FTP_PWD=oracle
FTP_LOCAL_PATH=${DUMP_DIR}
FTP_REMOTE_PATH=/u02/database/${TARGET_SID}/BNR/dump

ftp -nv >> $FTP_LOG <<EOF
open ${FTP_SRV}
user ${FTP_USR} ${FTP_PWD}
binary
cd ${FTP_REMOTE_PATH}
lcd ${FTP_LOCAL_PATH}
prompt
mput EXP_${ORACLE_SID}_${DT}.tar.gz
close
bye
EOF

RC=$?
flag=`cat ${FTP_LOG} | grep -i "receive OK" | grep -v grep`
if [ -z "${flag}" ] || [ "${RC}" -ne 0 ] ; then
    echo "FTP tar file to ${TARGET_SID} failed" >>${FTP_LOG}
    MAIL_SUB="FTP dump file from ${ORACLE_SID} to ${TARGET_SID} failed, please check !"
    mail -s $MAIL_SUB dba@trade.com <${FTP_LOG}
    exit 1
else
    echo "End ftp dump file to ${TARGET_SID} ...." >> ${FTP_LOG}
    echo "End ftp time at:" `date` --`date +%Y%m%d%H%M` >>${FTP_LOG}
    echo "">>${FTP_LOG}
    echo "-------------------------- End of the log file -----------------------">>${FTP_LOG}
    MAIL_SUB="FTP the dump file from ${ORACLE_SID} to ${TARGET_SID} completed successful."
    mail -s $MAIL_SUB dba@trade.com <${FTP_LOG}
fi

find ${DUMP_DIR} -name "*ftp*" -mtime +$RETENTION -exec rm {} \;
find ${DUMP_DIR} -name "EXP_${ORACLE_SID}*.gz" -mtime +$RETENTION -exec rm {} \;

exit

2、补充说明 a、该脚本用于Oracle expdp导出的dump文件自动ftp到指定服务器的指定路径下 b、对于expdp导出文件的格式定义请参阅上一篇文章,Linux/Unix shell 自动导出Oracle数据库 c、由于导出与需要导入的数据库使用不同的SID,因此我们在脚本中定义了TARGET_SID d、在ftp之前,我们对原来的dump文件进行了gzip压缩以节省网络带宽与传送时间 e、对该脚本作相应修改,同样可以将RMAN的备份档案实现ftp到异机 f、要实现自动ftp,当然是将其部署到crontab,此不赘述

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Linux/Unix shell 自动导入Oracle数据库

          使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份...

    Leshami
  • ORACLE RAC 监听配置 (listener.ora tnsnames.ora)

        Oracle RAC 监听器的配置与单实例稍有不同,但原理和实现方法基本上是相同的。在Oracle中 tns进程用于为指定网络地址上的一个或多个Orac...

    Leshami
  • MySQL 主从延迟监控脚本(pt-heartbeat)

        对于MySQL数据库主从复制延迟的监控,我们可以借助percona的有力武器pt-heartbeat来实现。pt-heartbeat通过使用时间戳方式在...

    Leshami
  • sql server数据库备份压缩拷贝实例

    --数据库备份压缩拷贝实例:前提要安装RAR压缩软件 --声明变量 declare @day varchar(10),@dbname varchar(20),@...

    寻找石头鱼
  • 【极客周刊】互联网+来袭?电竞成比赛项目?更多前沿内容进来看!

    一川水巷
  • PHP数据结构-图的概念和存储结构

    随着学习的深入,我们的知识也在不断的扩展丰富。树结构有没有让大家蒙圈呢?相信我,学完图以后你就会觉得二叉树简直是简单得没法说了。其实我们说所的树,也是图的一种特...

    硬核项目经理
  • Kubernetes里的secret最基本的用法

    Secret解决了密码、token、密钥等敏感数据的配置问题,使用Secret可以避免把这些敏感数据以明文的形式暴露到镜像或者Pod Spec中。

    Jerry Wang
  • 画说 Ruby 与 Python 垃圾回收

    本文基于我在刚刚过去的在布达佩斯举行的RuPy上的演讲。我觉得趁热打铁写成帖子应该会比只留在幻灯片上更有意义。你也可以看看演讲录像。再跟你说件事,我在Ruby大...

    goodspeed
  • Kubernetes里的secret最基本的用法

    版权声明:本文为博主汪子熙原创文章,未经博主允许不得转载。 https://jerry.blog....

    Jerry Wang
  • Qt快捷屏幕截图

    Qt君

扫码关注云+社区

领取腾讯云代金券