热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Linux  crontab命令的使用

这篇文章主要介绍了Linuxcrontab命令的使用,帮助大家更好的理解和学习Linux系统,感兴趣的朋友可以了解下

1.命令简介

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

Linux 下的任务调度分为两类,系统任务调度和用户任务调度。

系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等。/etc/crontab 文件是系统任务调度的配置文件。

用户任务调度:用户定期要执行的工作,比如用户数据备份、定时邮件提醒等。用户可以使用 crontab 工具来定制自己的计划任务。所有用户定义的 crontab 文件都被保存在 /var/spool/cron 目录中,其文件名与用户名一致。

系统管理员可以通过/etc/cron.deny 和 /etc/cron.allow 这两个文件来禁止或允许用户拥有自己的 crontab 文件。

2.命令格式

crontab [-u USER] FILE
crontab [-u USER] [-l | -r | -e] [-i] [-s]
crontab -n [ HOSTNAME ]
crontab -c

3.选项说明

-u
	指定要设置定时任务的用户名
-l
	列出当前的定时任务
-r
	删除定时任务
-e
	编辑用户的定时任务。任务保存在 /var/spool/cron 目录下与用户名同名的文件中
-i
	在删除定时任务前询问用户是否确定删除
-s
	在进行编辑/替换之前,将当前的 SELinux 安全上下文字符串作为 MLS_LEVEL 附加到 crontab 文件
-n [HOSTNAME]
	此选项只有当 cron(8) 使用 -c 选项启动以支持集群环境时才使用,用于指定集群中哪个主机执行定时 crontab 文件中的定时任务。如果省略了主机名,则使用 gethostname(2) 返回的本地主机名
-c
	此选项只有当 cron(8) 使用 -c 选项启动以支持集群环境时才使用,用于查询集群中当前哪个主机执行定时 crontab 文件中的定时任务

4.用户配置文件

crontab 文件保存了用户的定时任务,以特定格式保存在 /var/spool/cron 目录下与用户名同名的文件中。例如如果是 root 用户,那么添加任务时,会在该路径下有一个 root 文件。Linux 的 cron 服务会每隔一分钟去读取一次 /var/spool/cron 目录下面所有的内容。

crontab 文件每一行代表一项任务,每项任务分为六个字段,前五个字段是时间字段,第六个字段是要执行的命令,格式如下:

minute hour day month week command

minute 分钟,取值范围 0 到 59;
hour 小时,取值范围 0 到 23;
day 日期,取值范围 1 到 31;
month 月份,取值范围 1 到 12,或 jan,feb,mar,apr…;
week 星期,取值范围 0 到 7,或 sun,mon,tue,wed,thu,fri,sat。注意 0 和 7 均代表星期日;
command 要执行的命令,可以是系统命令,也可以是自己编写的脚本文件;

在以上各个时间字段中,还可以使用以下特殊字符:

* 表示所有可能的值,例如 minute 是 *,表示每分钟都执行命令
, 可以用逗号隔开的值指定一个列表,例如,1,2,5,7,8,9
- 可以用整数之间的横杠表示一个范围,例如 2-6 表示 2,3,4,5,6
/ 可以用斜杠指定时间的间隔频率,例如 minute 为 */2 表示每两分钟执行一次命令

注意,crontab 文件注释符号为 #。

5.系统配置文件

除了用户的 crontab 文件,与定时任务相关的系统配置文件有:

/etc/crontab		系统定时任务配置文件
/etc/cron.d			自动定期需要做的任务
/etc/cron.hourly	每小时执行一次的任务
/etc/cron.daily		每天执行一次的任务
/etc/cron.weekly	每周执行一次的任务
/etc/cron.monthly	每月执行一次的任务
/etc/cron.allow  	该文件中所列用户允许执行定时任务
/etc/cron.deny  	该文件中所列用户不允许执行定时任务
/var/log/cron		crontab 的日志文件

Linux 的 cron 服务会每隔一分钟去读取一次 /etc/crontab 文件和 /etc/cron.d 目录下面所有的内容。/etc/cron.hourly、/etc/cron.daily、/etc/cron.weekly 和 /etc/cron.monthly 下的任务也会间接按照相应的周期被调用。

6.常用示例

(1)添加定时任务。

crontab -e
* * * * * command			# 每分钟执行一次 command
3,15 * * * * command		# 每小时的第 3 和第 15 分钟执行
3,15 8-11 * * * command		# 上午 8 点到 11点每小时第 3 和第 15 分钟执行
3,15 8-11 * * 1 command		# 每个星期一的上午 8 点到 11 点的第 3 和第 15 分钟执行
3,15 8-11 1 * * command		# 每个月一号上午 8 点到 11 点的第 3 和第 15 分钟执行
3,15 8-11 1 1 * command		# 每年一月一号上午 8 点到 11 点的第 3 和第 15 分钟执行
0 */2 * * * /sbin/service httpd restart	# 每隔两个小时在第 0 分时候重启一次 httpd

(2)查看定时任务。

crontab -l

(3)删除定时任务,即清除 /var/spool/cron 目录下 crontab 文件。危险动作,请注意备份。

crontab -r

(4)将指定的 crontab 文件还原到 /var/spool/cron 目录下。

crontab FILE

以上就是Linux crontab 命令的使用的详细内容,更多关于Linux crontab 命令的资料请关注其它相关文章!


推荐阅读
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • Ubuntu 9.04中安装谷歌Chromium浏览器及使用体验[图文]
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
author-avatar
梦傲天001_137
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有