转载自CSDN的shinjitsu的专栏,主要备份oracle的数据到windows上面!

首先是crontab的介绍。

名称 : crontab
使用权限 : 所有使用者
使用方式 :
   
crontab  filecrontab [ -u user ] [ -u user ] { -l | -r | -e }
说明 :
   
crontab 是用来让使用者在固定时间或固定间隔执行程式之用,换句话说,也就是类似使用者的时程表。-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。
参数 :
    -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv VISUAL joe)
    -r : 删除目前的时程表
    -l : 列出目前的时程表
时程表的格式如下 :
    f1 f2 f3 f4 f5 program
    其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星期中的第几天。program 表示要执行的程式。
    当 f1 为 * 时表示每分钟都要执行 program,f2 为 * 时表示每小时都要执行程式,其余类推
    当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其余类推
    当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为 */n 表示每 n 小时个时间间隔执行一次,其余类推
    当 f1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,f2 为 a, b, c,... 时表示第 a, b, c...个小时要执行,其余类推
    使用者也可以将所有的设定先存放在档案 file 中,用
crontab file 的方式来设定时程表。

注意 :
    当程式在你所指定的时间执行后,系统会寄一封信给你,显示该程式执行的内容,若是你不希望收到这样的信,请在每一行空一格之后加上 > /dev/null 2>&1 即可。

步骤:

1、在windows系统上,创建保存备份文件的路径/backup,并共享。


2、创建bash文件/usr/ffsdbback/backup.sh

#vi /usr/ffsdbback/backup.sh

输入

      #!/bin/sh
      #日期的取得,“`”为键盘左上角“1”左边的符号。   date后边必须有空格。   
      td=`date +%Y%m%d`
      #执行postgres数据库的备份。
      #pg_dump:备份命令。
      su postgres -c "/opt/powergres/bin/pg_dump -Ft ffsdb > /usr/ffsdbback/"$td.ffsdb.tar

      #备份文件(只备份部分文件夹)。
      tar -cvf /usr/ffsdbback/$td.file.tar /home/projects/intranet/WebRoot/keiji /home/projects/intranet/WebRoot/lib        /home/projects/intranet/WebRoot/adm_log /home/projects/intranet/WebRoot/houkoku        /home/projects/intranet/WebRoot/mail /home/projects/intranet/WebRoot/users /home/projects/intranet/WebRoot/wflow

      #加载windows共享到/mnt/backup文件夹下。
      mount -t smbfs -o username=base,password=baseadmin //192.168.0.248/backup /mnt/backup

      #copy文件到windows共享文件夹。
      cp /usr/ffsdbback/$td.file.tar /mnt/backup
      cp /usr/ffsdbback/$td.ffsdb.tar /mnt/backup

      #卸载
      umount -l /mnt/backup

3、修改文件属性,使其可执行

# chmod +x /usr/ffsdbback/backup.sh

4、修改/etc/crontab

#vi /etc/crontab

在下面添加

30 18 * * 1,3,5 root /usr/ffsdbback/backup.sh

表示每周1、3、5的18点30分执行备份

5、重新启动crond

# /etc/rc.d/init.d/crond restart

完成。