一、引言:
近无意之间看到salt有一个cron的模块,今天就在这里介绍linux crontab以及通过salt的cron对crontab的管理。
二、Linux crontab的介绍:
crontab是用于设置周期性被执行的指令。该命令从标准输入设备读取指令,并将其存放在"crontab"文件中,以供之后读取和执行。crontab存储的指令被守护进程激活,crond常常在后台运行,每一分钟检查是否有预定的作业需要执行。
2.1、crond的启动与关闭:
#查看crond的状态[root@A01-R07-I165-88 ~]# service crond status#关闭crond[root@A01-R07-I165-88 ~]# service crond stop#启动crond[root@A01-R07-I165-88 ~]# service crond start#重启crond[root@A01-R07-I165-88 ~]# service crond restart#重新加载crond[root@A01-R07-I165-88 ~]# service crond reload
2.2、全部配置文件
crontab在/etc目录下面存在cron.hourly,cron.daily,cron.weekly,cron.monthly,cron.d五个目录和crontab,cron.deny二个文件。
cron.daily是每天执行一次的Job;
cron.weekly是每个星期执行一次的Job;
cron.monthly是每个月执行一次的Job;
cron.hourly是每个小时执行一次的Job;
cron.d是系统自动定期需要做的任务,但是又不是按小时,按天,按星期,按月来执行的。
/etc/crontab的内容如下:
[root@A01-R07-I165-88 ~]# 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.deny文件就是用于控制不让哪些用户使用crontab的功能。
2.3、用户配置文件:
每个用户都有自己得的cron配置文件,通过crontab -e就可以编辑,一般情况下我们编辑完用户的cron配置文件保存退出后,系统会自动就存放于/var/spool/cron/目录中,文件以用户名命名。
linux的cron服务是每隔一分钟去读取一次/var/spool/cron/,/etc/crontab,/etc/cron.d下面的所有内容。
2.4、cron命令格式:
crontab [ -u user ] 文件
crontab [ -u user ] { -l | -r | -e }-u:指定某一用户
-e:执行文字编辑器来设定用户(当前用户或指定用户)时程表,内定的文字编辑器是vi.
-r:删除用户时程表.
-l:列出用户时程表.
2.5、cron文件格式:
* * * * * command
分 时 日 月 周 命令
第1列表示分钟1~59, 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31第4列表示月份1~12第5列标识号星期0~6(0表示星期天)
第6列要运行的命令
2.6、特殊用户:
[root@A01-R07-I165-88 cron]# crontab -l# Lines below here are managed by Salt, do not edit@reboot /root/cgroup_mkdir.sh
@reboot是指在开机后运行,且只运行一次,效果跟设置在/etc/rc.local中一样。
另外还有:
string meaning ------ -------
@reboot Run once, at startup.
@yearly Run once a year, "0 0 1 1 *".
@annually (same as @yearly)
@monthly Run once a month, "0 0 1 * *".
@weekly Run once a week, "0 0 * * 0".
@daily Run once a day, "0 0 * * *".
@midnight (same as @daily)
@hourly Run once an hour, "0 * * * *".
2.7、每10秒运行一次:
三、通过salt来管理crontab:
新增一条记录:
salt -L'*'cron.set_job yarn'10''9''1''*''*''source /home/yarn/.bashrc;find /sys/fs/cgroup/cpu/hadoop-yarn -mtime +15 -name "container_*" -exec rm -rf {} \;'"rm the container files"查看记录:
salt '*' cron.raw_cron yarn
删除记录:
salt '*'cron.rm_job yarn'source /home/yarn/.bashrc;find /sys/fs/cgroup/cpu/hadoop-yarn -mtime +15 -name "container_*" -exec rm -rf {} \;'minute='10'