Linux周期性计划任务crontab实现定时命令


目录

  • 一、cron服务
  • 二、cron的配置文件:
  • 三、/etc/crontab 这个文件负责安排由系统管理员制定的维护系统以及其他任务的crontab
  • 四、/etc/cron.d/ 这个目录用来存放任何要执行的crontab文件或脚本。
  • 五、权限
  • 六、创建cron脚本
  • 七、crontab用法
  • 八、例子:
  • crontab常见问题
    • crontab目录中的文件用途
    • crontab可以直接写脚本吗
    • 如何查看所有用户的计划任务

cron是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务 工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。周期性计划任务使用crontab命令。

一、cron服务

cron是一个linux下 的定时执行工具,可以在无需人工干预的情况下运行作业。

servicecrondstart//启动服务servicecrondstop//关闭服务servicecrondrestart//重启服务servicecrondreload//重新载入配置servicecrondstatus//查看服务状态

二、cron的配置文件:

/var/spool/cron/ 这个目录下存放的是每个用户包括root的crontab任务,每个任务以创建者的名字命名,比如tom建的crontab任务对应的文件就是/var/spool/cron/tom。一般一个用户最多只有一个crontab文件。

三、/etc/crontab 这个文件负责安排由系统管理员制定的维护系统以及其他任务的crontab

SHELL=/bin/bashPATH=/sbin:/bin:/usr/sbin:/usr/binMAILTO=rootHOME=/#Fordetailsseeman4crontabs#Exampleofjobdefinition:#.----------------minute(0-59)#|.-------------hour(0-23)#||.----------dayofmonth(1-31)#|||.-------month(1-12)ORjan,feb,mar,apr...#||||.----dayofweek(0-6)(Sunday=0or7)ORsun,mon,tue,wed,thu,fri,sat#|||||#*****user-namecommandtobeexecuted

MAILTO=root:是说,当 /etc/crontab 这个档案中的例行性命令发生错误时,会将错误讯息或者是屏幕显示的讯息传给谁?由于 root 并无法再用户端收信,因此,我通常都將这个 e-mail改成自己的账号,好让我随时了解系统的状态!

四、/etc/cron.d/ 这个目录用来存放任何要执行的crontab文件或脚本。

Linux下的计划任务--crontabLinux下的计划任务--crontab

root@ubuntu:~/codelab#cat/etc/crontab#/etc/crontab:system-widecrontab#Unlikeanyothercrontabyoudon'thavetorunthe`crontab'#commandtoinstallthenewversionwhenyoueditthisfile#andfilesin/etc/cron.d.Thesefilesalsohaveusernamefields,#thatnoneoftheothercrontabsdo.SHELL=/bin/shPATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin#mhdommondowusercommand17****rootcd/&&run-parts--report/etc/cron.hourly256***roottest-x/usr/sbin/anacron||(cd/&&run-parts--report/etc/cron.daily)476**7roottest-x/usr/sbin/anacron||(cd/&&run-parts--report/etc/cron.weekly)5261**roottest-x/usr/sbin/anacron||(cd/&&run-parts--report/etc/cron.monthly)#


01 * * * * root run-parts /etc/cron.hourly:在 #run-parts 这一行以后的命令,我们可以发现,五个数字后面接的是 root ,这一行代表的是『执行的级别为root身份』当然,你也可以将这一行改为成其他的身份!而 run-parts代表后面接的 /etc/cron.hourly是『一个目录内(/etc/cron.hourly)的所有可执行文件』,也就是说,每个小时的01分,系统会以root身份去/etc/cron.hourly这个目录下执行所有可执行的文件!后面三行也是类似的意思!你可以到 /etc/ 底下去看看,系统本来就预设了这4个目录!你可以将每天需要执行的命令直接写到/etc/cron.daily即可,还不需要使用到crontab -e的程式!

五、权限

crontab权限问题到/var/adm/cron/下一看,文件cron.allow和cron.deny是否存在
用法如下:
1、如果两个文件都不存在,则只有root用户才能使用crontab命令。
2、如果cron.allow存在但cron.deny不存在,则只有列在cron.allow文件里的用户才能使用crontab命令,如果root用户也不在里面,则root用户也不能使用crontab。
3、如果cron.allow不存在, cron.deny存在,则只有列在cron.deny文件里面的用户不能使用crontab命令,其它用户都能使用。
4、如果两个文件都存在,则列在cron.allow文件中而且没有列在cron.deny中的用户可以使用crontab,如果两个文件中都有同一个用户,以cron.allow文件里面是否有该用户为准,如果cron.allow中有该用户,则可以使用crontab命令。

AIX 中 普通用户默认都有 crontab 权限,如果要限制用户使用 crontab ,就需要编辑/var/adm/cron/cron.deny
HP-UNIX 中默认普通用户没得crontab 权限 ,要想放开普通用户的crontab 权限可以编

六、创建cron脚本

第一步:写cron脚本文件,命名为crontest.cron。

15,30,45,59****echo"xgmtest.....">>xgmtest.txt表示,每隔15分钟,执行打印一次命令

第二步:添加定时任务。执行命令 “crontab crontest.cron”。搞定
第三步:"crontab -l" 查看定时任务是否成功或者检测/var/spool/cron下是否生成对应cron脚本

注意:这操作是直接替换该用户下的crontab,而不是新增

七、crontab用法

crontab命令用于安装、删除或者列出用于驱动cron后台进程的表格。用户把需要执行的命令序列放到crontab文件中以获得执行。
每个用户都可以有自己的crontab文件。/var/spool/cron下的crontab文件不可以直接创建或者直接修改。该crontab文件是通过crontab命令创建的

在crontab文件中如何输入需要执行的命令和时间。该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。
每个域之间使用空格或者制表符分隔。格式如下:

minutehourday-of-monthmonth-of-yearday-of-weekcommands合法值00-5900-2301-3101-120-6(0issunday)
Linux下的计划任务--crontabLinux下的计划任务--crontab除了数字还有几个个特殊的符号就是""、"/"和"-"、",",代表所有的取值范围内的数字,"/"代表每的意思,"/5"表示每5个单位,"-"代表从某个数字到某个数字,","分开几个离散的数字。-l在标准输出上显示当前的crontab。-r删除当前的crontab文件。-e使用VISUAL或者EDITOR环境变量所指的编辑器编辑当前的crontab文件。当结束编辑离开时,编辑后的文件将自动安装。

八、例子:

每天早上6点

06***echo"Goodmorning.">>/tmp/test.txt//注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。

每两个小时

0*/2***echo"Haveabreaknow.">>/tmp/test.txt

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

023-7/2,8***echo"Haveagooddream">>/tmp/test.txt

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

0114*1-3commandline

1月1日早上4点

*commandlineSHELL=/bin/=/sbin:/bin:/usr/sbin:/usr/binMAILTO=root

每小时执行/etc/cron.hourly内的脚本

01****rootrun-parts/etc/cron.hourly、

每天执行/etc/cron.daily内的脚本

024***rootrun-parts/etc/cron.daily

每星期执行/etc/cron.weekly内的脚本

224**0rootrun-parts/etc/cron.weekly

每月去执行/etc/cron.monthly内的脚本

4241**rootrun-parts/etc/cron.monthly

注意: "run-parts"这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名。

每天的下午4点、5点、6点的5 min、15 min、25 min、35 min、45 min、55 min时执行命令。

5,15,25,35,45,5516,17,18***command

每周一,三,五的下午3:00系统进入维护状态,重新启动系统。

0015**1,3,5shutdown-r+5

每小时的10分,40分执行用户目录下的innd/bbslin这个指令:

10,40****innd/bbslink

每小时的1分执行用户目录下的bin/account这个指令:

1****bin/account

每天早晨三点二十分执行用户目录下如下所示的两个指令(每个指令以;分隔):

203***(/bin/rm-fexpire.lslogins.bad;bin/expire$#@62;expire.1st)

每年的一月和四月,4号到9号的3点12分和3点55分执行/bin/rm -f expire.1st这个指令,并把结果添加在mm.txt这个文件之后(mm.txt文件位于用户自己的目录位置)。

12,5534-91,4*/bin/rm-fexpire.1st$#@62;$#@62;mm.txtx

crontab常见问题

crontab目录中的文件用途

在 /etc 目录下, 关于crontab 的目录有 cron.d/ cron.daily/ cron.hourly/ cron.monthly/ cron.weekly/ 和一个文件 crontab 它们的作用是什么哦?

这些目录是避免在你设定的时间,刚好服务器关机准备的,还有一个延时计划任务工具叫做anacron 来执行这些延时计划任务脚本

crontab可以直接写脚本吗

这样写计划任务能实现每秒执行一次脚本

*****foriin`seq60`;do[shellscript];sleep1;done

如何查看所有用户的计划任务

crontab -l和cat /var/spool/cron/root执行的结果完全相同。可以理解为是一样的查询方式吗?

/var/spool/cron/和用户同名的文件记录了该用户的cron计划任务, crontab -l 就是把这个文件读取到标准输出上,也可以查看其它用户的计划任务


硬件防火墙和软件防火墙的区别有哪些?

近几年对于网络数据安全的要求越来越高,很多刚开始使用服务器的朋友可能不太了解硬件的防火墙和软件的防火墙的区别究竟是有哪些,以及他们各自的作用是什么?硬件防火墙是通过硬件和软件技术相结合来达到隔离内外部网络的目的的,软件防火墙呢则是通过纯软件的方式来去实现隔离内...
服务器安全硬件防火墙软件防火墙

研究人员发现 70 个 Web 缓存中毒漏洞,涉及 GitHub/GitLab 等

安全研究员 Iustin Ladunca(Youstin)近期针对许多网站(包括一些高流量的在线服务)进行了调研,结果发现了 70 个具有不同影响的缓存中毒漏洞。根据介绍,Web 缓存中毒攻击的目标是网络服务器和客户端设备之间的中间存储点,如 point-of...
漏洞服务器安全WebGitHubGitLab

如何使用JSPanda扫描客户端原型污染漏洞

关于JSPandaJSPanda是一款功能强大的客户端原型污染漏洞扫描工具,该工具可以对从源代码中收集的所有单词进行污染操作,并将其显示在屏幕上。因此,它可能会产生假阳性结果。这些输出信息仅为研究人员提供额外的安全分析信息,其目的并非实现完全的自动化操作。注意...
漏洞服务器安全扫描JSPanda

新的 Linux sudo 漏洞使本地用户获得 root 权限

近日被技术专家所发现的新 sudo 漏洞允许任何本地用户在不需要任何身份验证的情况下就可以在类 Unix 操作系统上获得 root 权限。Sudo 实际上就是一个 Unix 程序,它使系统管理员可以为 sudoers 文件中列出的普通用户提供有限的 root ...
linux漏洞服务器安全root权限sudo