首页 > 代码库 > 计划任务
计划任务
任务计划
Linux 任务计划、周期性任务执行:
未来的某时间点执行一次任务:
at
batch :系统自行选择空闲时间去执行此处指定的任务;
周期性运行某任务:
cron
at 任务
at :Ctrl键+d键 退出(单行输入)
at 命令:at [option] TIME
常用选项:
-V 显示版本信息:
-l: 列出指定队列中等待运行的作业;相当于atq
-d: 删除指定的作业;相当于atrm
-c: 查看具体作业任务
-f /path/from/somefile :从指定的文件中读取任务
-m: 当任务被完成之后,将给用户发送邮件,即使没有标准输出;
注意:作业执行命令的结果中的标准输出和错误以邮件通知给相关用户;
TIME: 定义出什么时候进行at 这项任务的时间:
HH:MM [YYYY-mm-dd]
noon, midnight, teatime (4pm),tomorrow
now+#{minutes,hours,days, OR weeks}
at时间格式:
HH:MM 02:00 在今日的HH:MM进行,若该时刻已过,则明天此时执行任务;
HH:MM YYYY-MM-DD 04:00 2016-09-20 规定在某年某月的某一天的特殊时刻进行该项任务
HH:MM[am|pm] [Month] [Date] :
04pm March 17
17:20 tomorrow
HH:MM[am|pm] + number [minutes|hours|days|weeks] 在某个时间点再加几个时间后才进行该项任务:
now + 5 minutes
04pm + 3 days
执行方式:
1)交互式 2)输入重定向 3)at –f 文件
依赖与atd 服务, 需要启动才能实现at任务;
at 队列存放在/var/spool/at 目录中;
通过/etc/at.{allow,deny} 控制用户是否能执行at 任务:
先寻找/etc/at.allow文件(白名单),文件用中的使用者才能使用at ,用没有在这个文件中的使用者则不能使用 at ( 即使没有写在at.deny当中);
如果/etc/at.allow找不存在,就寻找/etc/at.deny(黑名单)这个文件,若写在这个at.deny的使用者则不能使用at,而没有在个这个at.deny 文件中的使用者则可使用at命令;
如果某个用户在这两个文件中都存在,因白名单的优先级比黑名单高,所以,这个用户可以使用at这个命令;
如果两个文件都不存在,只有root可以使用at这个命令;
cron任务
cron:周期性任务计划;
相关的程序包:
cronie: 主程序包,提供crond 守护进程及相关辅助工具;
cronie-anacron :cronie 的补充程序;用于监控cronie任务执行状况;如cronie 中的任务在过去该运行的时间点未能正常运行,则anacron会随后启动一次此任务;
crontabs :包含CentOS 提供系统维护任务;
确保crond 守护处于运行状态:
CentOS 7:
systemctl status crond
CentOS 6:
service crond status
计划周期性执行的任务提交给crond ,到指定时间会自动运行:
系统cron 任务:系统维护作业
/etc/crontab
用户cron 任务:
crontab 命令
日志:/var/log/cron
一、系统cron 任务 : /etc/crontab
注释行以 # 开头
详情参见 man 5 crontab
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
例如:晚上9 点10 分运行echo 命令:
10 21 * * * centos /bin/echo "Howdy!"
时间表示法:
(1) 特定值;
给定时间点有效取值范围内的值;
(2) *
给定时间点上有效取值范围内的所有值;
表示“每...”
(3) 离散取值:
#,#,#
(4) 连续取值:-
#-#
(5) 在指定时间范围上,定义步长:
/#: # 即为步长
例如:每3 小时echo 命令;
0 */3 * * * centos /bin/echo "howdy!"
时间格式:
@reboot Run once after reboot.(每次重启就执行)
@yearly 0 0 1 1 * (每年1月1号执行)
@annually 0 0 1 1 *(每年1月1号执行)
@monthly 0 0 1 * * (每月1号执行)
@weekly 0 0 * * 0 (每星期日执行)
@daily 0 0 * * * (每天0点0分执行)
@hourly 0 * * * *
系统的计划任务:
/etc/crontab
/etc/cron.d/ 配置文件
/etc/cron.hourly/ 脚本
/etc/cron.daily/ 脚本
/etc/cron.weekly/ 脚本
/etc/cron.monthly/ 脚本
anacron 系统
运行计算机关机时cron 不运行的任务,CentOS6.0 以后版本取消anacron 服务,由crond 服务管理;
假设计算机没有一直开机;
对笔记本电脑、台式机、工作站及其它不一直开机的系统很重要;
对偶尔要关机的服务器很有用;
配置文件:/etc/anacrontab ,负责执行/etc/cron.daily /etc/cron.weekly /etc/cron.monthly 中系统任务。/etc/cron.hourly/ 由/cron.d/0hourly 执行:
字段1 :如果在这些日子里没有运行这些任务……
字段2 :在重新引导后等待这么多分钟后运行它
字段3 :任务识别器,在日志文件中标识
字段4 :要执行的任务
管理临时文件:
rhel6.0 使用/etc/cron.daily/tmpwatch 定时清除临时文件。
rhel7.0 使用systemd-tmpfiles-setup 服务实现
配置文件:
/etc/tmpfiles.d/*.conf
/run/tmpfiles.d/*.conf
/usr/lib/tmpfiles/*.conf
/usr/lib/tmpfiles.d/tmp.conf:
d /tmp 1777 root root 10d
d /var/tmp 1777 root root 30d
命令:
systemd-tmpfiles –clean|remove|create configfile
当执行任务时,更新/var/spool/anacron/ 文件时间戳;
二、用户cron
run-parts 运行这个文件中的所有任务;
crontab 命令定义,每个用户都有专用的cron 任务文件:/var/spool/cron/USERNAME
crontab 命令:
crontab [-u user] [-l | -r | -e] [-i]
-l: 列出所有任务;
-e: 编辑任务;
-r: 移除所有任务;
-i :同-r 一同使用,以交互式模式移除指定任务
-u user: 仅root 可运行,指定用户管理cron 任务
控制用户执行计划任务 :
/etc/cron.{allow,deny}
1,如果将用户加入黑名单:
即使你将某个用户加入黑名单,但是这个用户已经创建的任务还会继续执行,但不能继续创建任务;
2,如果将用户即加入黑名单也加入白名单:
将某个用户即加入黑名单也加入白名单,则这个用户不仅可以继续执行以前的任务,而且也可以创建新的任务;
3,如果黑名单和白名单都是空的,那么只有root用户可以创建任务:
注意:运行结果的标准输出和错误以邮件通知给相关用户
(1) COMMAND > /dev/null
(2) COMMAND &> /dev/null
对于cron 任务来讲,% 有特殊用途;如果在命令中要使用%,则需要转义;不过,如果把%放置于单引号中,也可以不用转义;
at 和crontab:
用 一次性作业使用 at
重复性作业使用crontab
Create at time crontab -e
List at -l crontab -l
Details at -c jobnum N/A
Remove at -d jobnum crontab -r
Edit N/A crontab -e
没有被重定向的输出会被邮寄给用户;
根用户能够修改其它用户的作业;
计划任务