Linux下crontab的使用及利用crontab系统定时处理事务

weikaixxxxxx 2011-06-09

这里是crontab的基本介绍,并且使用crontab来定时周期性的完成事务。

比如:我们每天需要备份数据库,或者定时执行某项转换任务等,crontab就派上用场了。

一 linux下crontab的使用
1.作用
使用crontab命令可以修改crontab配置文件,然后该配置由cron公用程序在适当的时间执行,该命令使用权限是所有用户。

2.格式
crontab [ -u user ] 文件
crontab [ -u user ] { -l | -r | -e }

3.主要参数
-e:执行文字编辑器来设定时程表,内定的文字编辑器是vi。
-r:删除目前的时程表。
-l:列出目前的时程表。

crontab文件的格式为“M H D m d cmd”。其中,M代表分钟(0~59),H代表小时(0~23),D代表天(1~31),m代表月(1~12),d代表一星期内的天(0~6,0为星期天)。cmd表示要运行的程序,它被送入sh执行,这个Shell只有USER、HOME、SHELL三个环境变量。

4.说明
和at命令相比,crontab命令适合完成固定周期的任务。

5.应用实例
设置一个定时、定期的系统提示:
[cao @www cao]#crontab -e
此时系统会打开一个vi编辑器。
如果输入以下内容:35 17 * * 5 wall "Tomorrow is Saturday I will go CS",
这样每个星期五17:35系统就会弹出一个终端,提醒星期六可以打打CS了!

用crontab命令实现每天定时的病毒扫描
前面已经介绍了一个简单的crontab命令操作,这里看一些更重要的操作。

(1)建立一个文件,文件名称自己设定,假设为caoproject:
#crontab -e

(2)文件内容如下:
05 09 * * * antivir
用vi编辑后存盘退出。antivir是一个查杀Linux病毒的软件,当然需要时先安装在系统中。

(3)使用crontab命令添加到任务列表中:
#crontab caoproject
这样系统内所有用户在每天的9点05分会自动进行病毒扫描。

6.高级应用:crontab每隔5分钟运行一个怎么写?

第1列分钟1~5 9
第2列小时1~2 3(0表示子夜)
第3列日1~3 1
第4列月1~1 2
第5列星期0~6(0表示星期天)
第6列要运行的命令 

那crontab每隔5分钟就可以有如下的写法:

0,5,10,15,20,25,30,35,40,45,50,55 * * * * /home/a.sh

1-59/5 * * * * /home/a.sh

*/5 * * * * /home/a.sh

呵呵,以此类推

0,30 18-23 * * * /apps/bin/dbcheck.sh
上面的例子表示在每天1 8 : 0 0至2 3 : 0 0之间每隔3 0分钟运行/ a p p s / b i n目录下的d b c h e c k . s h。

二利用系统crontab来定时执行备份文件,按日期对备份结果进行保存,达到备份的目的。

1、创建保存备份文件的路径/mysqlbak
#mkdir /mysqlbak                           //这个是建立在根目录下的
2、创建/usr/sbin/mysqlbak文件
#vi /usr/sbin/mysql bak
输入
rq=` date +%Y%m%d `
tar zcvf /mysqlbak/mysql$rq.tar.gz /var/lib/mysql/wiki
或者写成
rq=` date +%Y%m%d `
mysqldump  -u root -p123456 wiki | gzip > /mysqlbak/mysql$rq.sql.gz
//我这里是备份的是wiki 数据库用mysqldump 命令压缩.sql文件,相关mysqldump 命令清查看手册或者
建入以下命令#mysqldump --help 查看系统帮助
/var/lib/mysql是你数据库文件的目录,部分用户是/usr/local/mysql/data,每个人可能不同
/mysqlbak/表示保存备份文件的目录,这个每个人也可以根据自己的要求来做。
3、修改文件属性,使其可执行
# chmod +x /usr/sbin/mysqlbak
4、修改/etc/crontab
#vi /etc/crontab
在下面添加
01 3 * * * root /usr/sbin/mysqlbak
表示每天3点01分钟执行备份
5、重新启动crond
# /etc/rc.d/init.d/crond restart
完成。
这样每天你在/mysqlbak可以看到这样的文件
mysql20071119.tar.gz(mysql20071119.sql.gz)
你直接下载就可以了。
在恢复数据库时,在tar命令执行前,停止数据库服务进程或锁定数据库,否则恢复数据时,会出现数据库损坏的情形 

相关推荐