zoukankan      html  css  js  c++  java
  • crontab命令

    crontab命令被用来提交和管理用户的需要周期性执行的任务,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。

    语法:

    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 : 列出目前的时程表
    -u<用户名称>:指定要设定计时器的用户名称。
    

    crontab文件的含义:用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:

    minute   hour   day   month   week   command     顺序:分 时 日 月 周
    其中:
    minute: 表示分钟,可以是从0到59之间的任何整数。
    hour:表示小时,可以是从0到23之间的任何整数。
    day:表示日期,可以是从1到31之间的任何整数。
    month:表示月份,可以是从1到12之间的任何整数。
    week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。
    command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
    
    在以上各个字段中,还可以使用以下特殊字符:
    星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
    逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
    中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
    正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。
    
    例子:
    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…个小时要执行,其馀类推
    使用者也可以将所有的设定先存放在文件中,用 crontab file 的方式来设定时程表。

    crond服务

    /sbin/service crond start    //启动服务
    /sbin/service crond stop     //关闭服务
    /sbin/service crond restart  //重启服务
    /sbin/service crond reload   //重新载入配置
    

     查看crontab服务状态:

    service crond status
    

     手动启动crontab服务:

    service crond start
    

     查看crontab服务是否已设置为开机启动,执行命令:

    ntsysv
    

     加入开机自动启动:

    chkconfig –level 35 crond on
    

    实例:

    每1分钟执行一次command
    * * * * * command
    
    每小时的第3和第15分钟执行
    3,15 * * * * command
    
    在上午8点到11点的第3和第15分钟执行
    3,15 8-11 * * * command
    
    每隔两天的上午8点到11点的第3和第15分钟执行
    3,15 8-11 */2 * * command
    
    每个星期一的上午8点到11点的第3和第15分钟执行
    3,15 8-11 * * 1 command
    
    每晚的21:30重启smb 
    30 21 * * * /etc/init.d/smb restart
    
    每月1、10、22日的4 : 45重启smb 
    45 4 1,10,22 * * /etc/init.d/smb restart
    
    每周六、周日的1:10重启smb
    10 1 * * 6,0 /etc/init.d/smb restart
    
    每天18 : 00至23 : 00之间每隔30分钟重启smb 
    0,30 18-23 * * * /etc/init.d/smb restart
    
    每星期六的晚上11:00 pm重启smb 
    0 23 * * 6 /etc/init.d/smb restart
    
    每一小时重启smb 
    * */1 * * * /etc/init.d/smb restart
    
    晚上11点到早上7点之间,每隔一小时重启smb
    * 23-7/1 * * * /etc/init.d/smb restart
    
    每月的4号与每周一到周三的11点重启smb 
    0 11 4 * mon-wed /etc/init.d/smb restart
    
    一月一号的4点重启smb
    0 4 1 jan * /etc/init.d/smb restart
    
    每小时执行/etc/cron.hourly目录内的脚本
    01 * * * * root run-parts /etc/cron.hourly
    
    每月每天每小时的第 0 分钟执行一次 /bin/ls
    0 7 * * * /bin/ls
    
    在 12 月内, 每天的早上 6 点到 12 点中,每隔 20 分钟执行一次 /usr/bin/backup
    0 6-12/3 * 12 * /usr/bin/backup
    
    周一到周五每天下午 5:00 寄一封信给 alex@domain.name
    0 17 * * 1-5 mail -s "hi" alex@domain.name < /tmp/maildata
    
    每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分….执行 echo “haha”
    20 0-23/2 * * * echo "haha"
    
    下面再看看几个具体的例子:
    0 */2 * * * /sbin/service httpd restart  意思是每两个小时重启一次apache 
    50 7 * * * /sbin/service sshd start  意思是每天7:50开启ssh服务 
    50 22 * * * /sbin/service sshd stop  意思是每天22:50关闭ssh服务 
    0 0 1,15 * * fsck /home  每月1号和15号检查/home 磁盘 
    1 * * * * /home/bruce/backup  每小时的第一分执行 /home/bruce/backup这个文件 
    00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} ;  每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。
    30 6 */10 * * ls  意思是每月的1、11、21、31日是的6:30执行一次ls命令
    
  • 相关阅读:
    数据库日志文件太大的解决方法及原理
    邮件发送组件
    DataConnectionDialog 旧事重提
    从LINQ实例解析LINQ的另类用法,解决多条件组合问题
    重开BLOG.
    找个搜索结果总数原来可以用到这么多的技术
    Discuz3.2与Java 项目整合单点登陆
    一点感触
    Java 处理word文档后在前端展示
    大数据: 完全分布式Hadoop集群HBase安装
  • 原文地址:https://www.cnblogs.com/smile1/p/11967136.html
Copyright © 2011-2022 走看看