linux之crontab定时执行命令走过的坑坑

Learn from one's mistakes!

经历过坑坑,就会吃一堑长一智!错误使我们快速成长!

对crontab的基础了解:

利用crontab可以在linux上面创建定时任务工作,该工作会被记录到/var/spool/cron里面去,该记录已帐号为区分,不信你可以执行下面命令进去看下:

[root@ccw cron]# cd /var/spool/cron/
[root@ccw cron]# ls
root


crontab的执行定时任务的记录会写入到/var/log/cron这个文件中,不信你可以用下面命令查看

[root@ccw ~]# tail -f /var/log/cron

crontab的执行最低频率是一分钟,cron 会每分钟去读取一次 /etc/crontab 与 /var/spool/cron 里面的数据内容

crontab的基本命令操作:

crontab命令主要有3个参数:

  -e :编辑用户的crontab。执行crontab -e命令后就可以在里面编写定时任务执行命令;例子:

执行 crontab -e

# 此时会进入 vi 的编辑画面让您编辑工作!注意到,每项工作都是一行。

#分 时 日  月 周      任务的完整命令行

 *  *  *  *  *       /www/task.sh

  -l :列出用户的crontab的内容。

  -r :删除用户的crontab的内容。

查看crontab服务状态:service crond status

手动启动crontab服务:service crond start;一般不需要重新启动,但有些系统比较另类,就需要了!

走坑一:linux系统时间不正常,定时任务死活执行不了

php测试脚本执行没错,结果放到crontab里面就不行了;查了N久,结果坑比,因为php测试脚本有个时间对比,时间大于某个点(2016-12-13 9:00:00)就开始执行,由于系统时间没跟网络时间同步是错误的,结果测试的时候一直小于时间点(2016-12-13 9:00:00

跳坑方法,同步系统时间为网络时间,执行命令如下:

ntpdate cn.pool.ntp.org
hwclock -w

走坑二:环境变量引起,shell脚本单独执行ok,定时任务死活执行不了

写了个备份mysql数据库的脚本shell,单独执行没任务问题;但是放到crontab执行就不行了

跳坑方法,在shell脚本之前,执行下系统环境生效,如下:

#!/bin/sh
source /etc/profile


走坑三:执行权限设置引起,shell脚本没执行权限

跳坑方法:对需要执行的脚本执行命令:chmod +x  xx.shell

走坑四:执行定时任务重复执行

跳坑方法:需要加锁机制或者脚本自己处理

使用linux flock 文件锁实现任务锁定,解决冲突;当任务未执行完,则不会进行下一次任务执行。例子:

* * * * * flock -xn /tmp/mytest.lock -c 'php /home/test.php' 
flock命令详解如下:

-s, --shared:    获得一个共享锁  
-x, --exclusive: 获得一个独占锁  
-u, --unlock:    移除一个锁,通常是不需要的,脚本执行完会自动丢弃锁  
-n, --nonblock:  如果没有立即获得锁,直接失败而不是等待  
-w, --timeout:   如果没有立即获得锁,等待指定时间  
-o, --close:     在运行命令前关闭文件的描述符号。用于如果命令产生子进程时会不受锁的管控  
-c, --command:   在shell中运行一个单独的命令  
-h, --help       显示帮助  
-V, --version:   显示版本















你可能感兴趣的:(Ivan@_Linux专栏)