Linux13-计划任务crontab

目录

一、用户计划任务

1.1、定义用户计划任务的命令crontab

1.2、作业格式

二、系统计划任务cron

三、管理临时文件

3.1、systemd-tmpfiles命令与配置文件

3.2、用法举例


一、用户计划任务

1.1、定义用户计划任务的命令crontab

Linux提供了针对周期性作业的crond守护进程,默认开机启动。crond是由多个配置文件和系统范围内的文件控制的,每个用户对应一个配置文件,可以控制应执行周期性作业的确切时间。用户可以使用crontab命令来管理作业。常用的选项有

  • -l,列出当前用户的计划任务
  • -r,删除当前用户的所有计划任务
  • -e,编辑当前用户的计划任务
  • -u,指定用户来管理该用户的作业

其实,只要记住crontab -e来编辑作业配置文件,就足够进行作业的控制了。

1.2、作业格式

crontab -e编辑作业时,启动编辑器(默认是vi),生成的配置文件位于/var/spool/cron/<username>,以执行的用户名命名。正在编辑的文件每一行均有一个作业。允许有空行,注释的行以#开头。环境变量也可以使用格式NAME=value声明,并且影响声明所在行下面的所有行。crontab中的常见变量包括SHELL、PATH、MAILTO。设置SHELL改变执行命令的shell,设置PATH改变执行命令的PATH环境变量、设置MAILTO改变电子邮件地址。

SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

每个作业都包含六个字段,详述了作业执行的时间和内容。如果前五个字段与当前日期、时间相匹配,则会执行最后一个字段中的命令。这些字段按顺序是:分钟、小时、日、月、星期、命令。

前五个字段全部使用相同的语法规则:

  • * ,表示“无关紧要”
  • 数字,用于指定分钟、小时、日、月、星期;对于星期,0表示周日、1表示周一、……、6表示周六、7也表示周日
  • x-y,表示范围 x-y(含)
  • x,y,z,表示列表,列表可以包含范围,例如分钟列 5, 10-13, 17表示作业应当在每小时过去5、10、11、12、13、17分钟运行
  • */x,表示时间间隔,例如分钟列 */7表示每7分钟运行一次
  • 月、星期也可以使用Jan、Feb、……、Dec,Man、Tue、……、Sun这样的三个字母英文缩写来表示
  • 注意,如果日、星期字段都不是*,则改命令将在其中任意字段匹配时执行。

最后一个字段包含要执行的命令。如果命令包含未转义的百分比符号%,则该百分比符号江北当做新行。

举例

[root@server0 ~]# crontab -l
# 7月每周五上午9点到下午4点间每7分钟,将/etc/httpd目录打包放到/backup目录下,以httpd_YYYYmmdd.tar.gz命名
*/7 9-16 * Jul 5 /bin/tar czf "/backup/httpd_$(date +"\%Y\%m\%d").tar.gz" /etc/httpd/*

# 每个工作日23::58,在/backup目录里面找到最后修改时间再7天及以上且文件名以httpd开头的普通文件,并删除
58 23 * * 1-5    find /backup -name httpd* -type f -mtime +6 -exec rm '{}' \;

二、系统计划任务cron

除了了用户作业外,还有系统作业。

系统作业不是使用crontab命令定义的,而是在一组配置文件中进行配置的。这些配置文件之间的主要区别在于一个额外的字段,该字段位于星期和命令字段之间,用于指定作业在哪个用户下进行。

系统作业是在两个位置定义的:/etc/crontab和/etc/cron.d/*。管理员可以在/etc/cron.d/中放置文件,将作业分散到单独文件中。此外,还有预定义作业每小时、每天、每周、每月运行一次,这些作业分别定义于/etc/cron.hourly/、/etc/cron.daily/、/etc/cron.weekly/、/etc/cron.monthly/中的所有脚本。

[root@server0 ~]# ll /etc/cron*
-rw-------. 1 root root   0 Jan 28  2014 /etc/cron.deny
-rw-r--r--. 1 root root 451 Dec 28  2013 /etc/crontab

/etc/cron.d:
total 16
-rw-r--r--. 1 root root 128 Jan 28  2014 0hourly
-rw-r--r--. 1 root root 108 Mar 10  2014 raid-check
-rw-r--r--. 1 root root 235 Jan 27  2014 sysstat
-rw-r--r--. 1 root root 187 Jan 28  2014 unbound-anchor

/etc/cron.daily:
total 20
-rwxr-xr-x. 1 root root 332 Apr  9  2014 0yum-daily.cron
-rwx------. 1 root root 180 Jul 31  2013 logrotate
-rwxr-xr-x. 1 root root 618 Mar 18  2014 man-db.cron
-rwxr-x---. 1 root root 192 Jan 27  2014 mlocate
-rwx------. 1 root root 256 Mar 26  2014 rhsmd

/etc/cron.hourly:
total 8
-rwxr-xr-x. 1 root root 392 Jan 28  2014 0anacron
-rwxr-xr-x. 1 root root 362 Apr  9  2014 0yum-hourly.cron

/etc/cron.monthly:
total 0

/etc/cron.weekly:
total 0


[root@server0 ~]# cat /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

/etc/cron.hourly/*脚本是使用run-parts命令从/etc/cron.d/0hourly中定义的作业执行的。每日、每周、每月作业也是使用run-parts命令,但是是从其他配置文件/etc/anacrontab执行。/etc/anacrontab的语法与其他cron配置文件不同。

  • Period in days,每多少天运行一次该作业
  • Delay in minutes,启动该作业前,cron守护进程应等待多少时间
  • Job identifier,此为/var/spool/anacron/中的文件名称,该文件用于检验该作业是否已运行,从/etc/anacrontab启动作业时,更新此文件时间戳,同一时间戳可以用于检查作业上次执行的时间
  • Command,要执行的命令
[root@server0 ~]# cat /etc/cron.d/0hourly
# Run the hourly jobs
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
01 * * * * root run-parts /etc/cron.hourly


[root@server0 ~]# cat /etc/anacrontab
# /etc/anacrontab: configuration file for anacron

# See anacron(8) and anacrontab(5) for details.

SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# the maximal random delay added to the base delay of the jobs
RANDOM_DELAY=45
# the jobs will be started during the following hours only
START_HOURS_RANGE=3-22

#period in days   delay in minutes   job-identifier   command
1	5	cron.daily		nice run-parts /etc/cron.daily
7	25	cron.weekly		nice run-parts /etc/cron.weekly
@monthly 45	cron.monthly		nice run-parts /etc/cron.monthly

三、管理临时文件

3.1、systemd-tmpfiles命令与配置文件

system-tempfiles管理临时文件。在systemd启动系统后,其中一个启动的服务单元是system-tmpfiles-setup。该服务运行命令systemd-tmpfiles --create --remove。该命令会从/usr/lib/tmpfiles.d/*.conf、/run/tmpfiles.d/*.conf、/etc/tmpfiles.d/*.conf读取配置文件。系统会删除 配置文件中标记要删除的文件和目录,并且会创建(或修复权限) 配置文件中标记要创建的文件和目录。

命令systemd-tmpfiles --clean 解析的配置文件和systemd-tmpfiles --create相同。命令systemd-tmpfiles --clean清理文件和目录,配置文件中定义的最长期限,在此期限内尚未访问、更改或修改的文件都会被删除。

systemd-tmpfiles配置文件,tmpfiles.d(5)描述了systemd-tmpfiles的配置文件格式。基本格式是“类型”、“路径”、“模式”、UID、GID、“期限”和“参数”。“类型”指的是systemd-tmpfiles应执行的操作,例如d表示创建还不存在的目录,Z表示以递归方式恢复SELinux上下文以及文件权限和所有权。

NAME
       tmpfiles.d - Configuration for creation, deletion and cleaning of volatile and temporary files
SYNOPSIS
       /etc/tmpfiles.d/*.conf
       /run/tmpfiles.d/*.conf
       /usr/lib/tmpfiles.d/*.conf
The configuration format is one line per path containing type, path, mode, ownership, age, and argument fields:
           #Type Path        Mode UID  GID  Age Argument
           d    /run/user   0755 root root 10d -
           L    /tmp/foobar -    -    -    -   /dev/null

举例,在创建文件时
如果目录/run/systemd/seats 还不存在,则创建该目录,所有者为root:root,权限为rwxr-xr-x。系统不会自动清除该目录。
如果目录/home/student 还不存在,创建该目录。如果存在,则清空其所有内容。运行systemd-tmpfiles --clean时,删除超过一天时间内尚未被访问、更改、修改的文件。

d /run/systemd/seats 0755 root root -
D /home/student 0700 student student 1d

配置文件的优先级

  • /etc/tmpfiles.d/*.conf
  • /run/tmpfiles.d/*.conf
  • /usr/lib/tmpfiles.d/*.conf

/usr/lib/tmpfiles.d/*.conf 是由相关RPM软件包提供的,不应由系统管理员编辑。
/run/tmpfiles.d/*.conf 本身是易失性文件,通常由守护进程来管理自己的运行时临时文件。
/etc/tmpfiles.d/*.conf 供管理员配置自定义临时位置,以及覆盖供应商提供的默认值。
也就是说
如果/run/tmpfiles.d/ 中的文件与/usr/lib/tmpfiles.d/ 中的文件同名,则系统使用/run/tmpfiles.d/中的文件。
如果/etc/tmpfiles.d/ 中的文件与/run/tmpfiles.d/或/usr/lib/tmpfiles.d/ 中的文件同名,则系统使用/etc/tmpfiles.d/中的文件。
给定这些优先级后,管理员将相关文件复制到/etc/tmpfiles.d/,然后编辑该文件,就可以覆盖供应商提供的设置。

3.2、用法举例

/tmp默认保留10天,因为/usr/lib/tmpfiles.d/tmp.conf默认配置时这样的。在/tmp下创建一些文件,systemd-tmpfiles --clean不会清除这些文件。
我们把tmp.conf复制到/etc/tmpfiles.d/tmp.conf,编辑里面的内容,把默认的10d改成30s,再执行systemd-tmpfiles --clean就清理了。

[root@server0 ~]# touch /tmp/f{1..10}
[root@server0 ~]# ls /tmp/
bz2  f2  f5  f8  systemd-private-24m91X  systemd-private-fEnzlw  systemd-private-lFP1bX  systemd-private-VTqhEa
f1   f3  f6  f9  systemd-private-erTfJF  systemd-private-kgiu1u  systemd-private-mHPtTw  xz
f10  f4  f7  gz  systemd-private-eSyI17  systemd-private-LAsbs7  systemd-private-V43mBf
[root@server0 ~]# systemd-tmpfiles --clean
[root@server0 ~]# ls /tmp/
bz2  f2  f5  f8  systemd-private-24m91X  systemd-private-fEnzlw  systemd-private-lFP1bX  systemd-private-VTqhEa
f1   f3  f6  f9  systemd-private-erTfJF  systemd-private-kgiu1u  systemd-private-mHPtTw  xz
f10  f4  f7  gz  systemd-private-eSyI17  systemd-private-LAsbs7  systemd-private-V43mBf

[root@server0 ~]# cp /usr/lib/tmpfiles.d/tmp.conf /etc/tmpfiles.d/
[root@server0 ~]# vim /etc/tmpfiles.d/tmp.conf
d /tmp 1777 root root 30s

[root@server0 ~]# systemd-tmpfiles --clean
[root@server0 ~]# ls /tmp/
bz2  systemd-private-24m91X  systemd-private-eSyI17  systemd-private-kgiu1u  systemd-private-lFP1bX  systemd-private-V43mBf  xz
gz   systemd-private-erTfJF  systemd-private-fEnzlw  systemd-private-LAsbs7  systemd-private-mHPtTw  systemd-private-VTqhEa

再举例创建文件的,注意用的是systemd-tmpfiles --create命令

[root@server0 ~]# ls /run/
abrt          console            dmeventd-client  iprinit.pid    log          netreport       rhsm           sepermit        systemd
alsactl.pid   crond.pid          dmeventd-server  iprupdate.pid  lsm          NetworkManager  rpcbind.lock   setrans         tmpfiles.d
atd.pid       cron.reboot        faillock         ksmtune.pid    lvm          plymouth        rpcbind.sock   sm-notify.pid   tuned
auditd.pid    cups               gdm              libvirt        lvmetad.pid  pm-utils        rpc.statd.pid  spice-vdagentd  udev
avahi-daemon  dbus               initramfs        libvirtd.pid   mdadm        ppp             samba          sshd.pid        user
chronyd.pid   dhclient-eth0.pid  iprdump.pid      lock           mount        radvd           saslauthd      syslogd.pid     utmp

[root@server0 ~]# vim /etc/tmpfiles.d/zdir.conf
d /run/zdir 0700 root root 30s

[root@server0 ~]# systemd-tmpfiles --create
[root@server0 ~]# ls /run/
abrt          console            dmeventd-client  iprinit.pid    log          netreport       rhsm           sepermit        systemd     zdir
alsactl.pid   crond.pid          dmeventd-server  iprupdate.pid  lsm          NetworkManager  rpcbind.lock   setrans         tmpfiles.d
atd.pid       cron.reboot        faillock         ksmtune.pid    lvm          plymouth        rpcbind.sock   sm-notify.pid   tuned
auditd.pid    cups               gdm              libvirt        lvmetad.pid  pm-utils        rpc.statd.pid  spice-vdagentd  udev
avahi-daemon  dbus               initramfs        libvirtd.pid   mdadm        ppp             samba          sshd.pid        user
chronyd.pid   dhclient-eth0.pid  iprdump.pid      lock           mount        radvd           saslauthd      syslogd.pid     utmp
[root@server0 ~]# ll -d /run/zdir/
drwx------. 2 root root 40 Mar 27 08:50 /run/zdir/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

苦行僧(csdn)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值