本文主要是介绍RH134-第十七节-定时任务和延时任务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
系统延时任务
延时任务是临时的,执行过后就自动取消了
at命令
at + time(时间点)
at 6:45
date (任务)
ctrl+d 发起任务
at -l | atq #查看当前任务,包含job号
atrm | at -d job号 #取消指定任务
at -c +job号 #查看任务内容
at now+1min #延时一分钟
at now+1min -f file #延时执行文件中的内容(文件不是脚本)
at -m #延时命令没有输出时也发送邮件给执行者
at -M #延时命令即使有输出也不发送邮件给执行者
at命令的执行权力设定
/etc/at.deny
用户黑名单,此名单中的用户不能执行at命令
/etc/at.allow
用户白名单,此名单默认不存在,建立后除了root用户,所有用户均没有at命令执行权限,此名单中的用户才有at命令执行权限
定时任务
定时任务是永久的,定时任务程序crond,在系统中每分钟做任务扫描
发起方式一
crontab -u username -e ##username用户建立定时任务
格式:
分 时 天 月 周 (每个之间都有空格)+ 命令
crontab -u username -r ##查看某用户的定时任务
crontab -u username -l ##删除某用户的定时任务
注意:
如果执行时crontab -e这样没有指定用户,程序会默认执行的是当前用户发起的定时任务,加上-u就指定用户发起定时任务
例如每天早上9点整root用户在/home/scofield/Pictures/下建立以当天日期为名字的文件夹,并且日期格式为2017-08-03这样的
发起方式二
vim /etc/cron.d/filename 创建一个文件并在里面填写,此文件可以填写多个用户
格式:
分 时 天 月 周 + 用户 + 命令
* * * * * root touch /mnt/file ##表示每分钟在/mnt目录下建立一个文件file
* 总结:
* at 指令的延迟任务是一次性的,执行完了就完了,用户不受限制(没有设立黑白名单)
* crontab命令和 /etc/cron.d/missions下写的文件都可以指定定时任务,相比at命令它具有周期性循环性执行特点;crontab -e 只能是一个用户的一个或者多个定时任务,而/etc/cron.d/这个目录下的文件却是可以多用户多时间点的定时任务,所以在写的时候必须指定用户
定时任务中时间表示方法
m h d m d+ 命令
上述数字填写范围
* —- 每(如每分钟)
m(分钟) —- 0-59
h(小时) —- 0-23
d(天) —- 1-31
m(月) —- 1-12
d(周) —- 0-7 (0和7都表示星期天)
/2 * * * 表示每2钟都执行一次
crontab命令的执行权力设定
/etc/cron.deny
(直接在文件中写用户名) 用户黑名单,此名单中的用户不能执行crontab命令
/etc/cron.allow
用户白名单,此名单默认不存在,建立后除了root用户所有用户均没有at命令执行权限,此名单中的用户才有crontab命令执行权限
系统中的临时文件
系统中服务在正常运行时会产生临时文件
在系统中 /usr/lib/tmpfiles.d/ 目录下存放
系统的临时文件配置是 /usr/lib/tmpfiles.d/*.conf
自己创建的临时文件配置文件必须以.conf结尾
临时文件配置的编写方式是:
文件类型 文件名 文件权限 文件所有人 文件所有组 文件存在的时间
d /mnt/westos 777 root root 10s
##表示在/mnt目录下创建临时目录westos,并且十秒内不能被删除
systemd-tmpfiles –create /usr/lib/tmpfiles.d/* ##执行临时文件配置
systemd-tmpfiles –clean /usr/lib/tmpfiles.d/* ##清理临时文件
这篇关于RH134-第十七节-定时任务和延时任务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!