热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux中crond服务与crontab的编写

crond服务是一种守护进程crond服务通常被放在etcinit.dcrond,这样就可以在系统启动后自动启动crond服务。Linux中的用户使用contab命令来配置

crond服务是一种守护进程

crond服务通常被放在/etc/init.d/crond , 这样就可以在系统启动后自动启动crond服务。
Linux中的用户使用contab命令来配置corn任务。 crontab在/etc目录下面存在cron.d,cron.daily,cron.weekly,cron.monthly,cron.hourly五个目录和crontab文件。

  • cron.d是系统自动定期需要做的任务,但是又不是按小时,按天,按星期,按月来执行的,那么就放在这个目录下面。如果是按小时,按天,按星期,按月的来执行的话,则可以放到相应的目录下面去。
  • cron.hourly是每个小时执行一次的任务
  • cron.daily是每天执行一次的任务
  • cron.weekly是每个星期执行一次的任务
  • cron.monthly是每月执行一次的任务

用vi 查看crontab文件
这里写图片描述
前四行是用来配置crond任务运行的环境变量。

  • 第一行SHELL变量指定了系统要使用哪个shell,这里是bash。
  • 第二行PATH变量指定了系统执行 命令的路径。
  • 第三行MAILTO变量指定了crond的任务执行信息将通过电子邮件发送给root用户,如果MAILTO变量的值为空,则表示不发送任务 执行信息给用户。

如何使用crontab 命令添加或者编辑需要定时执行的任务:
命令格式 crondtab [-u user] file/-l/-r/-e
如果使用该选项,就是指定了是某个具体用户的crontab文件将被修改。

如果不指定该选项,crontab 将默认是当前操作用户的crontab ,也就是执行该crontab命令用户的crontab文件将被修改。
crontab file //用指定文件代替目前的crontab
crontab -l //列出某个用户cron服务的详细内容
crontab -r //删除某个用户的cron服务(所有服务)
crontab -e //编辑某个用户的cron服务

比如说root查看自己的cron设置:crontab -u root -l
root想删除fred的cron设置: crontab -u fred -r


crontab的文件有六个参数,格式为: M H D m d command
如最上边的图一样,分别代表:

  • minute(0 - 59) //分钟,0-59之间的整数
  • hour(0-23) //小时
  • day(1-31) //日期,如果指定了月份,日期必须正确
  • month(1-12) //月份
  • day of week(1-7) //一周中的日期,也可以用英文的缩写如sun, mon
  • command //表示要执行的命令

*的作用:
星号(*)可以用来代表所有有效的值。比如:月份值中的星号,表示在满足其它制约条件后每月都执行该命令。
当 H 为 * 时表示每分钟都要执行 command,f2 为 * 时表示每小时都要执行任务,其余类推
整数间的短线(-)的作用 :
当 H 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其余类推
整数间的正斜线(/)可以用来指定间隔频率:
当 H 为 /n 时表示每 n 分钟个时间间隔执行一次,f2 为 /n 表示每 n 小时个时间间隔执行一次,其余类推
整数间的逗号(,)的作用 :
当 H 为 a, b, c,… 时表示第 a, b, c,… 分钟要执行,f2 为 a, b, c,… 时表示第 a, b, c…个小时要执行,其余类推。


crontab的常用例子 :

每天早上7点执行一次 /bin/ls :

0 7 * * * /bin/ls

每天早上6点10分

10 6 * * * date

每两个小时

0 * / 2 * * * date

晚上11点到早上8点之间每两个小时,早上8点

0 23-7/2,8 * * * date

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

0 11 4 * mon-wed date

1月份日早上4点

0 4 1 jan * date
linux系统的管理员经常用到crontab的例子 :

在 12 月内, 每天的早上 6 点到 12 点中,每隔3个小时执行一次 /usr/bin/backup :

0 6-12/3 * 12 * /usr/bin/backup

每晚的21:30重启apache。

30 21 * * * /etc/init.d/apache2 restart

每月1、10、22日的4 : 45重启apache

45 4 1,10,22 * * /etc/init.d/apache2 restart

每周六、周日的1 : 10重启apache。

10 1 * * 6,0 /etc/init.d/apache2 restart

在每天18 : 00至23 : 00之间每隔30分钟重启apache。

0,30 18-23 * * * /etc/init.d/apache2 restart

每星期六的11 : 00 pm重启apache。

0 23 * * 6 /etc/init.d/apache2 restart

每月的4号与每周一到周三的11点重启apache

0 11 4 * mon-wed /etc/init.d/apache2 restart

1月1日的4点重启apache

0 4 1 jan * /etc/init.d/apache2 restart

查看cron运行日志:
查看/var/log/cron.log这个文件就可以,用tail -f/var/log/cron.log观察。

参考链接


推荐阅读
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文深入探讨了 PHP 实现计划任务的方法,包括其原理、具体实现方式以及在不同操作系统中的应用。通过详细示例和代码片段,帮助开发者理解和掌握如何高效地设置和管理定时任务。 ... [详细]
  • 本文介绍了如何在Django项目中使用django-crontab库来设置和管理定时任务,包括安装、配置、编写定时任务以及常见问题的解决方案。通过具体实例,帮助开发者快速掌握在Django中实现自动化任务的方法。 ... [详细]
  • 本文详细介绍了在Linux环境下如何有效地管理任务,包括撤销操作、挂起与恢复任务、终止后台程序以及取消定时任务的方法。这些技巧对于提高日常工作效率和系统维护至关重要。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了在Unix/Linux环境下,如何有效地管理和运行长期或无限期运行的Python进程。文章不仅提供了关于进程崩溃后的处理方法,还讨论了使用Cron和Inetd等工具来优化进程管理的策略。 ... [详细]
author-avatar
草原华子无敌_531
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有