• 在Linux下利用Crontab定时备份文件

    2008-04-10

    分类:开发手记

    版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
    http://www.mryang.org/logs/18811980.html

      回到家的这几日,一直为学院网站的时常罢工寻找原因,到现在还没有找到确切的原因。不过为了不让这么长时间来的数据丢失,还是先做一个定时的备份。找了很多资料后发现利用crontab命令可以完成。

    关于crontab命令

      使用方式 :
      crontab [ -u user ] file
      crontab [ -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 的方式来设定时程表。

    备份过程

      定时备份采用crontab命令定时来执行一个shell脚本来实现。脚本可以命名为backup.sh,放到/bin下。第一步,使用vi建立该脚本:

      vi /bin/backup.sh

      以下是脚本内容:

      bakdate=` date +%Y%m%d `   //利用当天的日期来为备份文件命名。

      tar zcvf /mysqldata/mysql$bakdate.tar.gz /var/lib/mysql      //将mysql的所有数据库打包

      打包的命令中/mysqldata是存放备份文件的目录,/var/lib/mysql是数据库存放目录。 

      第二步,修改该脚本的权限,加上可执行权限。命令如下:

      chmod 700 backup.sh

       第三步,利用crontab设定备份时间。命令如下:

      crontab –e

      进入vi,在里面加入执行时间即可。如下:

      30 2 * * * /home/scripts/backup.sh //每天2:30分执行backup.sh

       第四步,重启crontab。命令如下:

      service crond stop

      service crond start


    收藏到:Del.icio.us

发表评论

您将收到博主的回复邮件
记住我