Linux自学笔记——Linux周期性计划任务

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

周期性运行某任务:crontab

执行结果:会通过邮件形式发送给用户;

本地邮件服务:

smtp:simple mail transmission protocol;

pop3:post office procotol;

imap4:internet mail access procotol;

mail命令:

mailx - send and receive Internet mail;

MUA:mail user agent,用户收发邮件的工具程序;

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

邮件正文的生成:

(1)交互式输入:.

单独成行表示正文结束;ctrl+d提交亦可;

(2)通过输入重定向;

(3)通过管道;

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:查看指定作业的具体内容;

#at –c job_number

-q QUEUE:指明队列;

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

batch命令:

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

周期性任务计划:cron

服务程序;

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

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

Centos 7:

systemctl status crond.service

active:active(running)

centos 6:

service crond status

… is running

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

cron任务分为两类:

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

手动编辑:/etc/crontab文件

用户cron任务:

命令:crontab命令

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

Note:

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

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

username:运行任务的用户身份

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) ORjan,feb,mar,apr ...

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

#|  | |  |  |

#*  * *  *  *  command to be executed

注意:

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

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

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

时间表示法:

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

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

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

(3)离散取值:,

在时间点上使用逗号分隔的多个值:#,#,#

(4)连续取值:-

在时间点上使用-连接开头和结束:#-#

(5)在指定时间点上,定义步长:

/#:#即步长;

注意:

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

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

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

示例:

(1)3 * * * *:每小时执行一次,每小时的第三分钟执行;

(2)3 4 * * 5:每周执行一次,每周五的四点零三分执行;

(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及其应用:

anacron - runs commands periodically

配置文件:/etc/anacrontab

periodin days:轮回天数,即是指任务多少天执行一次,monthly是一个月(30天)执行一次,weekly即是     指一周之内执行一次;

delay in minutes:是指轮回内的重试时间,这个意思有两部分,一个是anacron启动以后该服务ready暂不运行的时间(周任务的25 delay在anacron启动后的25分钟不执行,处于ready状态),另一个意思是指如果该任务到达运行时间却因为某种原因没有执行(比如前一个服务没有运行完成,anacron在/etc/init.d的脚本中加了一个 -s参数,便是指在前一个任务没有完成时不执行下一个任务),依然以周任务和月任务为例,周任务在启动anacron后的25分钟后执行,月任务在服务启动后的45分钟执行,但是如果月任务到达服务后45分钟时,周任务运行超过5分钟依然没有完成,那月任务将会进入下一个45分钟的轮回,在下一个45分钟在检查周任务是否完成,如果前一个任务完成了那么月任务开始运行。

job-identifier:任务标识符,anacron每次启动都会在/var/spool/anacron里面建立一个以job-identifier为文件名的文件,里面记录着任务完成的时间,如果任务时第一次运行的话那个文件是空的。

command:记录着你想要运行的程序,run-parts可以一次运行整个目录的可执行程序,在/usr/bin路径下。

练习:

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

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

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

时间: 2024-10-26 13:51:34

Linux自学笔记——Linux周期性计划任务的相关文章

Linux自学笔记——linux文件系统

Linux的文件系统 根文件系统(rootfs),内核挂载的第一个文件系统,在启动流程的这一篇文章里有提到: LSB,FHS(Filesystem  Herirache Standard) 常用的文件系统目录:/etc,/usr,/var,/root/,/home,/dev 目录介绍:(以下截图很多是目录内容的部分截图) /boot:引导文件存放目录,内核文件(vmlinuxz).引导加载器(bootloader,grub)都存放于此目录: /bin:供所有用户使用的基本命令:不能关联至独立分区

Linux自学笔记——linux进程及作业管理

内核的功用主要有进程管理.文件系统.网络功能.内存管理.驱动程序.安全功能这几个方面,本文主要讨论linux进程及作业管理. 进程管理: 进程,process,运行中程序的一个副本,且存在生命周期: 进程分为CPU bound和I/Obound. CPU bound:CPU密集型(类似于高清视频) I/O bound:IO密集型(编辑器等频繁IO操作) Linux内核存储进程信息的固定格式为:task struct(结构体) 多个任务的task struct组件的链表:task list 进程创

Linux自学笔记——Linux网络基础、命令及属性配置

网络对于Linux来说不可或缺的一部分,本文主要对linux网络的基础知识,常用配置命令以及linux配置文件的属性等等作一个总结. 计算机网络: TCP/IP协议栈: TCP/IP分为4层,分别为应用层,传输层,网络互连层,主机到网络层,不同于OSI,他将OSI中的会话层.表示层规划到应用层,把数据链路层和物理层划分给主机到网络层. OSI,Open System Interconnection,开放式系统互联,国际化标准组织ISO制定了OSI模型,该模型定义了不同计算机互联的标准,是设计和描

linux自学笔记--linux网络配置、基础网络命令

1.网络配置 /etc/sysconfig/net-script/ifcfg-* DEVICE:接口名 UUID:设备唯一标示 HWADDR:网卡地址 ONBOOT:是否开机自启 BOOTPROTO:static|none|dhcp TYPE:Ethernet|Bridge DNS1:dns地址 PEERDNS:如果为dhcp模式,是否自动分配dns地址,覆盖手动 IPADDR:ip地址 NETMASK:子网掩码 GATEWAY:网关地址 2.常用网络命令 ip: ip link show ip

Linux 自学笔记(一)

    Linux系统简介 UNIX与Linux发展史: 1965年,由MIT,GE,AT&T贝尔实验室联合开发multics项目.后由于项目过于复杂,项目进度落后于计划,最终宣告失败. 1969年,贝尔实验室的工程师肯.汤姆森在DEC的机器上开发出了UNIX系统. 1971年,丹尼斯.里奇发明了C语言,并在1973年,用C语言把UNIX系统进行了重新编写,这为UNIX系统的可移植打下了基础. TCP/IP协议的开发,并捆绑在UNIX上,使得UNIX的发展和推广启到很大的作用. UNIX的主要发

Linux自学笔记——LVM2的创建与管理

LVM2,Logical VolumeManager,逻辑卷管理,它是linux环境下对磁盘分区进行管理的一种机制,它由Heinz Mauelshagen在linux 2.4内核上实现.Linux用户安装Linux操作系统时遇到一个常见的难以决定的问题就是如何正确的评估各分区的大小,已分配合适的硬盘空间.普通的磁盘分区管理方式在逻辑分区划分好之后就无法改变其大小,当一个逻辑分区存放不下某个文件时,这个文件因为受上层文件系统的限制,也不能跨越多个分区来存放,所以不能同时放到别的磁盘上.而遇到出现某

Linux自学笔记——keepalived

本文部分参考博客:http://blog.51cto.com/1992tao/1869869 一.        VRRP协议 1.      技术优点: VRRP是一种容错协议,它保证当主机的下一跳路由器出现故障时,由另一台路由器来代替出现故障的路由器进行工作,从而保持网络通信的连续性和可靠性. VRRP具有如下优点: 1)      简化网络管理.在具有多播或广播能力的局域网(如以太网)中,借助VRRP能在某台设备出现故障时仍然提供高可靠的缺省链路,有效避免单一链路发生故障后网络中断的问题,

Linux自学笔记--基础命令date,cal等

逆水行舟,不进则退: date命令: 我们可以来man一下date命令,可以在上面看出 date的含义为 - print or set the system date and time,我们从以下几方面对date命令进行阐述. 1.   显示时间 date[OPTION]... [+FORMAT] format:格式符号 %D: %F: %T: 在屏幕中输入单独的date命令可以显示系统的时间: 同时我们也可以显示自己想要的时间显示格式: 2.   设置时间 date[-u|--utc|--un

linux自学笔记——RAID级别特性以及软RAID的实现

RAID,Redundant Arrays of Inexpensive Disks 廉价冗余磁盘阵列,又称为Redundant Arrays of Independent Disks,独立冗余磁盘阵列. 其基本原理就是利用多块较小的磁盘通过不同的组织方式,组成一个大的磁盘组,以提高磁盘的IO能力和耐用性.由于组织方式不同,所以把RAID分为多个级别.而最常用的是RAID0,RAID1,RAID5,RAID6,RAID10,RAID01.下面我们将对以上的级别进行比较分析. 级别:level R