-
版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明
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
随机文章:
Ubuntu 7.10 Server上配置较完整的Web Server 2008-04-22又回到USTC了 2008-04-14在出差前半小时搞定乱码问题 2007-07-10痛苦的网站搬家 2007-06-26今天看到一个被黑网站 2007-08-16
收藏到:Del.icio.us