任务计划

所谓计划任务就是指某一个时间系统自动做一件事情如输入指令或者保存文件等等 
计划任务分两种:一次性计划任务命令(at)和周期性计划任务命令(crontab)
at的用法:如果当前时间为2017年6月6日 
at 18:00 2017-06-6

w > /root/who.txt 
init 0 
(输入ctrl+d结束编辑) 
此时将意味着我们的系统将在第二天的傍晚6点执行两个命令,一个是将当时系统访问的客户列表做一个另存为,另一个是关机。 
这个命令将是一次性执行。 
这个任务会生成一个可执行文件到/var/spool/at/这个目录中可以通过cat查看其中文件内容 
atq或者at -l:这两个命令是将制定的计划列出清单会工作的id和执行时间
atrm [id]或者at -d [id]:这两个命令是将指定的任务删除,具体删哪个任务是由任务的id决定的。 
at -c [id] :这个命令是通过工作id来查看计划中的内容的等同于直接查看/var/spool/at/目录中的可执行文件。 
(注:查看#at -l; 删除#at -d [id]; 查看计划内容#at -c [id])

at这个功能本身是一项开机及执行的服务,利用chkconfig --list atd可以看到atd这个服务是在全字符模式和图形模式默认开启的 

。如果这个服务被关闭了我们也可以通过两种方式来开启它。 
第一种 /etc/init.d/atd {start|stop|restar|stadues|…} 
第二种 service atd {start|stop|restar|stadues|…} 
at有黑白名单分别为 
/etc/at.deny黑名单此名单中的用户不可以使用at命令centos默认有这个文件。 
/etc/at.allow白名单这个文件默认没有可以自己创建,这个文件意味着只有白名单的用户可以使用at功能其他人都不可以。 
如果两个文件中都有同一个用户那么allow优先。 
有的操作系统可能没有安装at功能我们可以通过rpm -q at 来查看at工具有没有安装如果没有下载一个装上即可centos系统自带。 
说到at也可以顺带提一个命令batch。 
batch的用法和at基本相同而且batch可以不指定时间,或者即使指定了时间到时也未必会执行计划的操作。 
因为batch会考虑系统的负载状况当负载状况低于0.8才会执行其中的操作。

下面来介绍周期性计划cron
 所谓周期性就是设定等任务计划会根据你指定的时间条件进行周期性的执行。这样就不用像at一样一条一条制定了。

用法具体如下: 
crontab -e -u (user)这是对用户进行任务编辑;如果直接输入crontab -e 则是对当前用户建立计划 
进入计划编辑界面后就可以编辑计划了计划是已行分开的每一行是一个计划。格式如下: 
分 (0~59) 时(0~23)日期 (1~31)月(1~12)星期(0~7)命令 如果用*则表示通配其中星期0和7都代表星期天。 
如果我们想在每年的2月和12月的1号和28号的晚上八点到12点每半个小时向系统所在的所有用户广播see your back 
编辑为 /30 20-0 1,28 2,12 wall “see your back” 
注意:由于每年的星期几和日期搭配是会变化的,所以星期几和日期时间不要同时写,以免系统会真的等到若干年后两个时间重合再运行你指定的命令。 
如果我们是root用户时也可以通过vim在家目录编辑一个内容为周期运行的指令文件,这样我们通过命令 crontab -u student /root/文件名 来为student用户设置计划。 
计划编辑好后查询命令为 crontab -l -u (user)同时也可以到/var/spool/cron/这个目录中,通过cat查看其中文件内容 
删除命令 crontab -r -u (user) 这种删除方式会将用户的所有计划全盘删除因此不建议使用,还是应该进入编辑模式来有目的的删除。 
这个周期性计划服务也是默认开启的开关的方法也是两种 
第一种 /etc/init.d/crond {start|stop|restar|stadues|…} 
第二种 service crond {start|stop|restar|stadues|…} 
cron有黑白名单分别为 
/etc/cron.deny黑名单此名单中的用户不可以使用crontab命令centos默认有这个文件。 
/etc/cron.allow白名单这个文件默认没有可以自己创建,这个文件意味着只有白名单的用户可以使用crontab其他人都不可以。 
cron功能是否安装可以通过rpm -q vixie-cron来确认。

原创文章,作者:huchaowei,如若转载,请注明出处:http://www.178linux.com/77709

(0)
huchaoweihuchaowei
上一篇 2017-06-07
下一篇 2017-06-07

相关推荐

  • Hadoop hdfs分布式文件系统

    一、MapReduce理论基础 每个MapReduce job都是Hadoop客户端想要执行的一个工作单元,它一般由输入数据、MapReduce程序和配置信息组成,而Hadoop会把每个job分隔成两类任务(task):map任务和reduce任务。在Hadoop集群中有两类节点来执行两类job进程的执行 1.1 大数据处理 任何基础业务包含了收集、分析、监…

    2017-12-08
  • linux中的管道符

    管道符 less只能看文件 但是这样做会产生一个垃圾文件ls.txt,所以下面我们就会需要用到管道符 |只将传递正确结果传递给 而使用这两种方法可以传递正确和错误的结果[root@localhost ~]# ls /etc/passwd /cpp/passwd 2>&1|less   ,  (2>&1…

    2017-07-22
  • Linux的基础文件管理命令

    Linux用于管理文件的一些基本常见的命令如下: ls:  列出指定目录下的清单    -a  显示所有文件包括隐藏文件    -l  显示文件的详细信息    -d  查看目录自身   示例: cat:  可查看指定路径下的文件文本 fi…

    Linux干货 2016-11-06
  • 文件的查找与压缩归档

    文件的查找与压缩归档 locate find 压缩与归档 locate 主要用途 查询系统上预建的文件索引数据库 locate – find files by namelocate [OPTION]… PATTERN… locate查询文件时,会去搜索/var/lib/mlocat…

    Linux干货 2016-08-21
  • 线上多服务管理工具实例剖析

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1583156        公司线上对nginx、tomcat和jar包的java应用的服务管理脚本之前都是单独分离开…

    Linux干货 2016-08-15
  • LVM基本原理及使用

    LVM简介 LVM全称Logical Volume Manager(逻辑卷管理),是将几个物理分区(或硬盘)通过软件组合成一块看起来是独立大硬盘(VG),然后对这块大硬盘分割成可使用的逻辑卷(LV),最终能够挂载使用,以达到对磁盘空间进行弹性管理的目的。 LVM的基本原理 基本术语 dm(device mapper):将一个或多个底层块设备组织成一个逻辑设备…

    Linux干货 2016-04-17