ITPub博客

首页 > Linux操作系统 > Linux操作系统 > Linux 平台下 Oracle 数据泵备份(expdp) SHELL 脚本

Linux 平台下 Oracle 数据泵备份(expdp) SHELL 脚本

原创 Linux操作系统 作者:zhengbao_jun 时间:2011-08-08 10:13:17 0 删除 编辑

数据泵是Oracle 10g的新特性,10g以后的版本才有。 关于数据泵的理论知识参考我的Blog

Oracle 10g EXPDPIMPDP使用说明

http://blog.csdn.net/tianlesoftware/archive/2009/10/16/4674224.aspx

 

Logicalbackup.sh

#!/bin/ksh

# ##################################################################

#

#              created by tianlesoftware

#                   2010-7-7

#              Email: tianlesoftware@vip.qq.com

# ##################################################################

# Oracle Environment settings

PATH=/usr/bin:/usr/ucb:/etc:.:/usr/X/bin:/bin

export PATH

ORACLE_SID=SID; pw=oracle ; export pw ; export ORACLE_SID

ORACLE_BASE=/dba/oracle; export ORACLE_BASE

ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1;  export ORACLE_HOME

ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data ; export ORA_NLS33

TNS_ADMIN=$ORACLE_HOME/network/admin ; export TNS_ADMIN

LD_LIBRARY_PATH=$ORACLE_HOME/lib ; export LD_LIBRARY_PATH

PATH=$ORACLE_HOME/bin:/usr/local/bin:/usr/ccs/bin:$PATH:/usr/sbin

export PATH

CLASSPATH=$ORACLE_HOME/jlib:$ORACLE_HOME/product/jlib ; export CLASSPATH

backup_dir=/u03/oradata/dump_backup_dir

#数据泵需要directory,这里指定自己的目录就可以了
#SQL>CREATE DIRECTORY backup as ‘/u03/oradata/dump_backup_dir’;
#SQL>grant read,write on directory backup to SYSTEM

DMP_FILE=SID_`date +%d%m%Y_%H%M%S`.dmp

LOG_FILE=SID_`date +%d%m%Y_%H%M%S`.log

#

#  Let's start with an export of the database

#

expdp user/pwd DIRECTORY=dump_backup_dir DUMPFILE=$DMP_FILE TABLESPACES=TS_NAMEE logfile=$LOG_FILE  parallel=3;

这里的2个说明,用户名和密码换成自己的,我这里是备份表空间。 

parallel 这个参数是控制并行度的,默认是1,但对于数据库比较大的时候,可以设置parallel,这样可以较少备份的

#时间,但是设置并行会耗CPU 资源,如果CPU 资源比较紧张的话,就不要设了。

#

# Just to be safe (with space), we'll compress the export file

压缩dmp 文件,较少对空间的占用

#

cd $backup_dir

compress *.dmp

#

# Let's delete the backups and logs that are more than 1 days old

删除超过一天的dmp文件

#

find $backup_dir -name "NewccsTablespace*" -mtime +1 -exec rm {} /;

# That's all

 

 

 

部署的时候,只要把这个sh 脚本添加到crontab 中就可以了。 

添加方法: crontab -e 进入编辑状态,然后把脚本的路径和相关执行时间写上。保存后用crontab -l 就可以查看内容:

$ crontab -l

45 1 * * * /u03/scripts/logicbackup.sh

前面5个参数的意义:

059 表示分 

123 表示小时 

131 表示日 

112 表示月份 

0表示星期(其中0表示星期日) 

有于更多crontab 的使用,参考blog

Unix crontab 命令详解

http://blog.csdn.net/tianlesoftware/archive/2010/02/22/5315039.aspx

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/235507/viewspace-704379/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2008-08-08

  • 博文量
    209
  • 访问量
    870883