linux下定时器crontab的使用

项目开发中经常需要用将某个脚本定时运行,从而实现类似于windows平台的计划任务,并且避免其运行影响到其他程序。

下面是简略版:

$ chmod 777 some_script.sh # 保证脚本是可执行的

$ sudo crontab -e # -e参数表示进入编辑器添加所需的定时执行文件

00 22 * * * some_script.sh # 前5个参数是数字:第1个表示分;第2个是小时;第3个是天(月份中的第几天);第4个是月,第5个是天(星期中的第几天)。第6个参数是指定的文件

=========================================

Linux配置定时任务,大家都知道使用crontab这个系统功能,但有时候我们需要区分用户执行,下面就直接说一下2种方法的区别:

方法1:

使用命令 crontab -e 然后直接编辑定时脚本。

这样执行以后,属于用户自定义的,会被写到 /var/spool/cron 目录下,生成一个和用户名一致的文件,文件内容就是我们编辑的定时脚本。

[root@localhost cron.d]# cd /var/spool/cron
[root@localhost cron]# ll
总用量 4
-rw-------. 1 root root 52 12月  9 10:58 root
[root@localhost cron]# pwd
/var/spool/cron
[root@localhost cron]# cat root 
30 03 * * * /root/automysqlbackup.sh

方法2:

使用命令 vim /etc/crontab 编辑定时脚本。

如:

[root@localhost ~]# cat /etc/crontab                                                                                                                                                                      
SHELL=/bin/bash                                                                                                                                                                                           
PATH=/sbin:/bin:/usr/sbin:/usr/bin                                                                                                                                                                        
MAILTO=root                                                                                                                                                                                               
HOME=/

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed
                                                                                                                                                                                              
                                                                                                                                                                                                          
# run-parts                                                                                                                                                                                               
30 * * * * root /usr/sbin/ntpdate 210.72.145.44                                                                                                                                                           
#30 8 * * * root /usr/sbin/ntpdate 132.228.90.101                                                                                                                                                         
01 * * * * root run-parts /etc/cron.hourly                                                                                                                                                                
02 4 * * * root run-parts /etc/cron.daily                                                                                                                                                                 
22 4 * * 0 root run-parts /etc/cron.weekly                                                                                                                                                                
42 4 1 * * root run-parts /etc/cron.monthly                                                                                                                                                               
*/1 * * * * root run-parts /opt/openoffice.org3/program/start.sh                                                                                                                                          
############################################                                                                                                                                                              
                                                                                                                                                                                                          
30 4 * * * root /usr/bin/rsync -vzrtopg --progress --delete root@192.168.231.35::resource /hyy/bak/resource 
30 4 * * * root /usr/bin/rsync -vzrtopg --progress --delete root@192.168.231.35::log /hyy/bak/log
############################################
[root@localhost ~]# 

(系统级的)做系统级配置我们会直接配置 /etc/crontab

(用户级的)一般还是建议大家使用 crontab -e ,这样系统也会帮着检查我们配置的脚本语法。

crontab表达式 的一些例子:
30 21 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每晚的21:30重启apache。
45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每月1、10、22日的4 : 45重启apache。
10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每周六、周日的1 : 10重启apache。
0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。
0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每星期六的11 : 00 pm重启apache。
* */1 * * * /usr/local/etc/rc.d/lighttpd restart

如何通过cron执行的日志来分析crontab是否正确执行?

例如服务器下root用户有如下的计划任务
(base) [root@iZj6c0az1bftcl2q7m6i05Z log]# crontab -l
10 15 * * * /root/zk_info/articlespider/spider.sh
15 16 * * * /root/zk_info/zkService/run.sh

关于系统的计划任务都会写在/var/log

(base) [root@iZj6c0az1bftcl2q7m6i05Z log]# cd /var/log
(base) [root@iZj6c0az1bftcl2q7m6i05Z log]# less cron

上面的/var/log/cron只会记录是否执行了某些计划的脚本,但是具体执行是否正确以及脚本执行过程中的一些信息则linux会每次都发邮件到该用户下。

如上述root的计划任务执行信息,linux会发邮件到/var/spool/mail下面

(base) [root@iZj6c0az1bftcl2q7m6i05Z log]# cd /var/spool/mail/
(base) [root@iZj6c0az1bftcl2q7m6i05Z mail]# ll
total 40212
-rw------- 1 root mail 41172810 Nov 21 16:16 root
(base) [root@iZj6c0az1bftcl2q7m6i05Z mail]# less root

此时我们就能很好的判断crontab脚本是否执行,已经执行过程中是否正确以及一些错误的信息,希望这个可以帮助有些朋友很好的了解crontab的原理和诊断crontab的问题。

查看日志

crontab是Linux下最常用的计划任务服务。本文跟大家分享一下有关linux crontab日志存放的一些心得,希望本文能教会你更多东西。

默认情况下,crontab中执行的日志写在/var/log下,如:

#ls /var/log/cron*
/var/log/cron /var/log/cron.1 /var/log/cron.2 /var/log/cron.3 /var/log/cron.4

如果日志有问题,可以参考以下做法:

为crontab增加日志

crontab的日志比较简单,当crond执行任务失败时会给用户发一封邮件。恰巧在我们的一台服务器上发现一个任务没有正常执行,而且crond发邮件也失败了。通过看mail的日志,看到是磁盘空间不足造成的。

此外,同事帮我为crontab中的任务增加自己的日志,这样出错后,比较容易看到原因。

0 6 * * * $HOME/for_crontab/createTomorrowTables >> $HOME/for_crontab/mylog.log 2>&1

把错误输出和标准输出都输出到mylog.log中。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值