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

这里是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/mysqlbak4、修改/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命令执行前,停止数据库服务进程或锁定数据库,否则恢复数据时,会出现数据库损坏的情形

愈想得到,就愈要放手。放手是很难的,但是别无选择。

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

相关文章:

你感兴趣的文章:

标签云: