Linux/Unix shell 自动导出Oracle数据库

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

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

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

Linux/Unix shell 脚本中调用SQL,RMAN脚本

Linux/Unix shell sql 之间传递变量

Linux Unix shell 调用 PL/SQL

1、自动导出Oracle数据库shell脚本

# +——————————————————-+
# +    Export database by schema every day                |
# +    Author : Robinson                                  |
# +    Blog  : -0612        |
# +    Usage  :                                          |
# +        expdb.sh $ORACLE_SID                          |
# +——————————————————-+
#
#!/bin/bash
# ——————–
# Define variable
# ——————–

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

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

ORACLE_SID=$1;                export ORACLE_SID
DT=`date +%Y%m%d`;            export DT
TIMESTAMP=`date +%Y%m%d_%H%M`
MAIL_LIST=”robinson.chen@12306.com”; export MAIL_LIST
MAIL_DIR=/users/robin/dba_scripts/sendEmail-v1.56
MAIL_FM=’oracle@szdb.com’
LOG_DIR=/users/robin/dba_scripts/custom/log
LOG_FILE=$LOG_DIR/expdb_${ORACLE_SID}_${TIMESTAMP}.log
DUMP_FILE=EXP_${ORACLE_SID}_${DT}.dmp
DUMP_LOG=EXP_${ORACLE_SID}_${DT}.log
DUMP_DIR=/u02/database/${ORACLE_SID}/BNR/dump
RETENTION=1

# ————————————————————————
#  Check the target database status, if not available send mail and exit
# ————————————————————————

db_stat=`ps -ef | grep pmon_$ORACLE_SID | grep -v grep| cut -f3 -d_`
if [ -z “${db_stat}” ]; then
    MAIL_SUB=” $ORACLE_SID is not available on `hostname` before try to export data  !!!”
    $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -m $MAIL_SUB
    exit 1
fi;

# ————————————
#  Check the dumpfile exist or not
# ————————————

if [ -s “${DUMP_DIR}/${DUMP_FILE}” ]; then
    MAIL_SUB=” The dump file ${DUMP_FILE} exists for ${ORACLE_SID} on `hostname`, exit !!!!”
    $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -m $MAIL_SUB
    exit 1
fi

echo “`date`” >>$LOG_FILE
echo “The hostname is :`hostname`”>>$LOG_FILE
echo “The database is :${ORACLE_SID}”>>$LOG_FILE
echo ”  Start to export data ……………” >>$LOG_FILE

# ————————————–
#  Start to export data
# ————————————–

expdp ‘/ as sysdba’ directory=db_dump_dir dumpfile=${DUMP_FILE} logfile=${DUMP_LOG} schemas=goex_admin #parallel=3
RC=$?

echo ” “>>$LOG_FILE
cat ${DUMP_DIR}/${DUMP_LOG} >>$LOG_FILE
echo ” “>>$LOG_FILE
echo “————————- End of the log file ————————“>>$LOG_FILE

flag=`cat ${DUMP_DIR}/${DUMP_LOG} | grep -i “successfully completed”`

if [ “${RC}” -eq 0 ] && [ -n “${flag}” ];then
    MAIL_SUB=” Export database ${ORACLE_SID} finished successful on `hostname`  !!!”
    $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -o message-file=$LOG_FILE
else
    MAIL_SUB=” Export database ${ORACLE_SID} failed on `hostname`  !!!”
    $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -o message-file=$LOG_FILE
fi

# ————————————————
# Removing files older than $RETENTION parameter
# ————————————————

find ${LOG_DIR} -name “expdb*.*” -mtime +$RETENTION -exec rm {} ;
find ${DUMP_DIR} -name “EXP*” -mtime +$RETENTION -exec rm {} ;

exit

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1901060.html

(0)
上一篇 2025年2月22日 14:47:18
下一篇 2025年2月22日 14:47:40

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Linux/Unix shell 自动 FTP 备份档案

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

    数据库 2025年2月22日
    200
  • Linux/Unix shell 自动导入Oracle数据库

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

    数据库 2025年2月22日
    200
  • Linux/Unix shell sql 之间传递变量

    灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给 灵活结合linux/unix shell 与sql 之间的变量传输,,极…

    数据库 2025年2月22日
    300
  • Linux Unix shell 调用 PL/SQL

    Linux/Unix 下除了调用SQL之外,调用PL/SQL也是DBA经常碰到的情形,下面主要通过一些示例给出如何在shell下面来调用pl/sql。 linux/unix 下除了调用sql之外,调用pl/sql也是dba经常碰到的情形,下…

    数据库 2025年2月22日
    200
  • 再谈Oracle 11g 远程导出数据库

    1、创建TNS字符串: zqxt = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 132.97.172.186)( 1、创建tns字符串: zqxt =…

    数据库 2025年2月22日
    200

发表回复

登录后才能评论