码迷,mamicode.com
首页 > 其他好文 > 详细

计划任务

时间:2016-09-13 22:40:17      阅读:316      评论:0      收藏:0      [点我收藏+]

标签:crontab


任务计划


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

没有被重定向的输出会被邮寄给用户;

根用户能够修改其它用户的作业;





计划任务

标签:crontab

原文地址:http://alwaysli.blog.51cto.com/11880605/1852337

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!