周期性任务

Linux任务计划、周期性任务执行

导言:假如你下班了,有些工作还需要做,你不用在那里守着而是在一个时间点自动执行一个任务帮你完成你的工作。我们来探讨这个话题吧



     有两个工具:

未来的某时间点执行一次某任务:at, batch

周期性运行某任务:crontab   执行结果:会通过邮件发送给用户

    at命令:

at  [OPTION]... TIME

TIME:

HH:MM [YYYY-mm-dd]

noon,midnight, teatime

tomorrow

now+#

UNIT:minutes, hours, days, OR weeks

注:at的作业有队列,用单个字母表示,默认都使用a队列;

常用选项:

-l:查看作业队列,相当于atq

-f /PATH/FROM/SOMEFILE:从指定文件中读取作业任务,而不用再交互式输入;

-d:删除指定的作业,相当于atrm;

-c:查看指定作业的具体内容;

-q QUEUE:指明队列;

注意:作业执行结果是以邮件发送给提交作业的用户;

周期性任务计划:cron

服务程序:

cronie:主程序包,提供了crond守护进程及相关辅助工具;

确保crond守护进程(daemon)处于运行状态:

查看其运行状态:

CentOS 7:systemctl  status  crond.service

CentOS 6: service  crond  status

向crond提交作业的方式不同于at,它需要使用专用的配置文件,此文件有固定格式,不建议使用文本编辑器直接编辑此文件;要使用crontab命令;

cron任务分为两类:

系统cron任务:主要用于实现系统自身的维护;

用户cron任务:

执行方式: 手动编辑:/etc/crontab文件

命令:crontab命令

系统cron的配置格式:/etc/crontab

SHELL=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

# For details see man 4 crontabs

# Example of job definition:

# .---------------- minute (0 - 59)

# |  .------------- hour (0 - 23)

# |  |  .---------- day of month (1 - 31)

# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...

# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat

# |  |  |  |  |

# *  *  *  *  * user-name  command to be executed

注意:

(1) 每一行定义一个周期性任务,共7个字段;

*  *  *  *  * : 定义周期性时间

user-name : 运行任务的用户身份

command to be executed:任务

(2) 此处的环境变量不同于用户登录后获得的环境,因此,建议命令使用绝对路径,或者自定义PATH环境变量;

(3) 执行结果邮件发送给MAILTO指定的用户

用户cron的配置格式:/var/spool/cron/USERNAME

SHELL=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

# For details see man 4 crontabs

# Example of job definition:

# .---------------- minute (0 - 59)

# |  .------------- hour (0 - 23)

# |  |  .---------- day of month (1 - 31)

# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...

# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat

# |  |  |  |  |

# *  *  *  *  *   command to be executed

注意:

(1) 每行定义一个cron任务,共6个字段;

(2) 此处的环境变量不同于用户登录后获得的环境,因此,建议命令使用绝对路径,或者自定义PATH环境变量;

(3) 邮件发送给当前用户;

时间表示法:

(1) 特定值;给定时间点有效取值范围内的值;

注意:day of week和day of month一般不同时使用;

(2) *   给定时间点上有效取值范围内的所有值;表“每..”

(3) 离散取值:,   在时间点上使用逗号分隔的多个值; #,#,#

(4) 连续取值:-  在时间点上使用-连接开头和结束  #-#

(5) 在指定时间点上,定义步长:  /#:#即步长;

注意:

(1) 指定的时间点不能被步长整除时,其意义将不复存在;

(2) 最小时间单位为“分钟”,想完成“秒”级任务,得需要额外借助于其它机制;

定义成每分钟任务:而在利用脚本实现在每分钟之内,循环执行多次;

示例:

(1) 3 * * * *:每小时执行一次;每小时的第3分钟;
(2) 3 4 * * 5:每周执行一次;每周5的4点3分;
(3) 5 6 7 * *:每月执行一次;每月的7号的6点5分;
(4) 7 8 9 10 *:每年执行一次;每年的10月9号8点7分;
(5) 9 8 * * 3,7:每周三和周日;
(6) 0 8,20 * * 3,7:
(7) 0 9-18 * * 1-5:
(8) */5 * * * *:每5分钟执行一次某任务;
(9) */7

crontab命令:

crontab [-u user] [-l | -r | -e] [-i]

-e:编辑任务;

-l:列出所有任务;

-r:移除所有任务;即删除/var/spool/cron/USERNAME文件;

-i:在使用-r选项移除所有任务时提示用户确认;

-u user:root用户可为指定用户管理cron任务;

            注意:运行结果以邮件通知给当前用户;如果拒绝接收邮件:



(1) COMMAND > /dev/null

(2) COMMAND &> /dev/null

注意:定义COMMAND时,如果命令需要用到%,需要对其转义;但放置于单引号中的%不用转义亦可;

思考:某任务在指定的时间因关机未能执行,下次开机会不会自动执行?

不会!.

如果期望某时间因故未能按时执行,下次开机后无论是否到了相应时间点都要执行一次,可使用anacron

实现;

课外作业:anacron及其应用;

练习:

1、每12小时备份一次/etc目录至/backups目录中,保存文件 名称格式为“etc-yyyy-mm-dd-hh.tar.xz”

2、每周2、4、7备份/var/log/secure文件至/logs目录中,文件名格式为“secure-yyyymmdd”;

3、每两小时取出当前系统/proc/meminfo文件中以S或M开头的行信息追加至/tmp/meminfo.txt文件中;

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

编外:

mail命令:

mailx - send and receive Internet mail

MUA:Mail User Agent, 用户收发邮件的工具程序;

mailx  [-s ‘SUBJECT‘]  username[@hostname]

邮件正文的生成:

(1) 交互式输入;. 单独成行可以表示正文结束;Ctrl+d提交亦可;

(2) 通过输入重定向;

(3) 通过管道;


batch命令:

batch会让系统自行选择在系统资源较空闲的时间去执行指定的任务;

时间: 2024-08-28 12:51:07

周期性任务的相关文章

Linux 任务计划,周期性任务执行

Linux 任务计划.周期性任务执行 概述: 什么是任务计划呢?就像我们每个人日常生活中都会使用到的闹钟一样,按时的去提醒该去做什么事情,以免忘记.同样,我们在工作当中也要在每天在特定的时间内安排做一些事情,这就是任务计划,本章将学习如何制定Linux系统的任务计划,这里主要包括两种工具:at和crontab. 一.定义 1.任务计划的分类:      一次性的任务计划:只执行一次就结束:      周期性的任务计划:每隔一定的时期去做相同的事情:2.使用的命令      未来时间点执行一次某任

at、cron周期性任务计划详解

一.一次性任务计划:at.batch 1.batch:系统自行选择在系统资源较空闲的时间去执行指定的任务 用法类似于at,但只要提交所需执行的命令 2.at:指定未来的某时间点执行一次某任务 (1)用法格式:at   [OPTION]...   TIME 1)TIME格式: HH:MM [YYYY-mm-dd]:直接指明具体的时间 noon,midnight, teatime:中午.午夜.下午茶时间(下午四点左右) tomorrow:明天 now+#:现在之后的多久,可使用表示单位为minute

Linux周期性任务计划详解

一次性任务执行: at,batch at: 交互式:让用户在at>提示符输入多个要执行命令: 批处理:将任务的各命令写入文件由at进行调用: 使用格式: at TIME at > Ctrl+d:提交任务 at作业有队列:使用单个字母表示 查看作业:at -l =atq [[email protected] ~]# at 10:46 at> ls -ld /etc at> <EOT> job 1 at 2015-08-25 10:46 [[email protected]

4、定时器T1通过查询方式控制LED1周期性闪烁(轮训方式)

定时器T1通过查询方式控制LED1周期性闪烁 1 /**************************************************************************** 2 * 文 件 名: main.c 3 * 作 者: Amo [ www.amoMcu.com 阿莫单片机] 4 * 修 订: 2014-04-08 5 * 版 本: 1.0 6 * 描 述: 定时器T1通过查询方式控制LED1周期性闪烁 7 *************************

性能測试JMeter趟的坑之JMeter的bug:TPS周期性波动问题

先说下问题: 我在做性能測试时,使用JMeter搞了100个并发,以100TPS的压力压測十分钟,但压力一直出现波动.并且出现波动时JMeter十分卡,例如以下图: 周期性TPS波动 各种猜測: 所以開始找环境的各种原因,起初以为是JMeter的连接被"劫持"了,不然JMeter也不会卡的.所以,花了整整一下午时间.去排除压測机环境.被压測环境(TCP连接数.程序上的问题等等),但一直没找到原因. 后来.换成LR后,压測正常.所以開始怀疑是JMeter自身的问题. 原因找到: 后来想起

Centos 7周期性任务、日志rotation、过滤和core压缩的实现

Centos 7周期性任务日志rotation.过滤和core压缩的实现 1.centos7中cron脚本及其调用脚本的实现示例 [[email protected] cron.d]# pwd /etc/cron.d [[email protected] cron.d]# cat syslog # Run mysys activity accounting tool every 10 minutes */5 * * * * root /usr/sbin/mysyslog.sh 2>&1 &g

网格数值计算中周期性边界条件的处理

涉及到网格的数值计算中,边界条件的处理总是一个比较烦人的东西. 一者,本来好好的逐格处理过程,到边界这里总是要中断一下,或者加两个if,或者for循环中要精心处理下标关系,以免混乱,动不动就给你来个数组越界. 二者,并行计算的时候,最好的情况是所有网格统一处理.尤其是在CUDA编程中,代码中出现if很有可能大大降低执行效率.如果只对中间的网格进行并行处理,那么边界点的网格,单独做处理边界的kernel太烦,拷贝回内存处理更是得不偿失. 最近几天正在学习Level Set算法,研究从网上下载的代码

8、周期性任务、find、break和continue 学习笔记

find [options] [查找路径] [查找条件] [处理动作] 查找路径:默认为当前目录 查找条件:默认为查找指定路径下的所有文件 处理动作:默认为显示 查找条件: -name "文件名称" 支持使用globbing正则表达式 -iname "文件名称" 查找时不区分字符大小写 -user UserName 根据属主查找 -group GroupName 根据属组查找 -uid UID 根据uid查找 -gid GID 根据gid查找 -nouser 查找没

周期性计划任务

循环性计划任务   周期性计划任务      安装软件        crontabs-1.10-33.el6.noarch        cronie-1.4.4-7.el6.x86_64        查看crontabs软件有无安装        # rpm -qa |grep crontabs 启动服务        # /etc/init.d/crond  start   默认是启动的        # chkconfig |grep crond   默认2 3 4 5 是启动的   

Java ScheduledThreadPoolExecutor延迟或周期性执行任务

WorkerThread类 package com.cninfo.ThreadTest; import java.util.Date; public class WorkerThread implements Runnable{   private String taskname;       public WorkerThread(int i){         this.taskname="第"+i+"个任务";     }       @Override