首页 > 代码库 > 自动备份Oracle 11g数据库

自动备份Oracle 11g数据库

采用Linux提供的crontab定时任务触发器。实施过程如下:

一、使用oracle帐号登录

二、在/home/oracle目录下添加XXXXX.sh脚本。

内容:export ORACLE_SID=XXXXX

export ORACLE_BASE=/u1/app/oracle

export ORACLE_HOME=/u1/app/oracle/product/11.2.0.3/db

export PATH=$ORACLE_HOME/bin:$PATH

filename=$(date +%y%m%d)

exp system/oracle@(SID) file=/var/dbbak/$filename.dmp owner=(SID User)              

三、添加XXXXXX.sh文件执行权限

chmod u+x mesdbbackup1.sh

四、使用crontab -e命令添加linux排程

30 2 * * * /home/oracle/XXXXXX.sh(每天早上2:30进行备份)测试阶段设定

Crontab 格式说明

 

       我们可以用crontab -e 添加要执行的命令。 命令执行的结果,无论是标准输出还是错误输出,都将以邮件形式发给用户。

     

   添加的命令必须以如下格式:

   * * * * * /command path

     

       前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。

 

 前5个字段分别表示:

       分钟:0-59

       小时:1-23

       日期:1-31

       月份:1-12

       星期:0-6(0表示周日)

 

还可以用一些特殊符号:

       *: 表示任何时刻

       ,: 表示分割

  -:表示一个段,如第二端里: 1-5,就表示1到5点

       /n : 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1.

 

一些示例:

00 8,12,16 * * * /data/app/scripts/monitor/df.sh

30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh

10 8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh

 

43 21 * * * 21:43 执行

15 05 * * *    05:15 执行

0 17 * * * 17:00 执行

0 17 * * 1 每周一的 17:00 执行

0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行

0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行

0 0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行

42 4 1 * *     毎月1日的 4:42分 执行

0 21 * * 1-6   周一到周六 21:00 执行

0,10,20,30,40,50 * * * * 每隔10分 执行

*/10 * * * *        每隔10分 执行

* 1 * * *         从1:0到1:59 每隔1分钟 执行

0 1 * * *         1:00 执行

0 */1 * * *        毎时0分 每隔1小时 执行

0 * * * *         毎时0分 每隔1小时 执行

2 8-20/3 * * *      8:02,11:02,14:02,17:02,20:02 执行

30 5 1,15 * *       1日 和 15日的 5:30 执行

 

备份结果:

       自动备份设定为每天早上2:30进行。从下图可以看出在10-16下午实施后,系统已在17日早上自动进行备份。

 

       自动备份Log日志

 

 

自动备份Oracle 11g数据库