Ansible——cron模块

cron 模块管理远程主机中的计划任务,功能相当于 crontab 命令。

一、计划任务示例

示例1
每天的1点5分输出 test 字符

5 1 * * * echo test

示例2
每3天执行一次计划任务,于当天的1点1分执行,具体任务为输出 test 字符

1 1 */3 * * echo test

示例3
每次系统启动后需要执行一次计划任务,具体任务为输出 test 字符

@reboot echo test

示例4
每小时执行一次计划任务,具体任务为输出 test 字符

@hourly echo test

二、常用参数

minute:设置计划任务中分钟设定位的值,默认为””。
hour:同上
day:同上
month:同上
weekday:此参数用于设置计划任务中周几设定位的值,默认为”
”。
special_time:可用值有 reboot(重启后)、yearly(每年)、annually(每年,与yearly相同)、monthly(每月)、weekly(每周)、daily(每天)、hourly(每时)。
注意:当上述时间单位设定参数都未指定时,计划任务的时间设定默认会被设定为”* * * * *”,这样表示每秒都会执行一次计划任务,所以,在使用cron模块时,我们应该确定对应的时间参数设置正确。
user:设置当前计划任务属于哪个用户。
job:指定计划的任务中需要实际执行的命令或者脚本。
name:设置计划任务的名称。
state:当计划任务有名称时,修改或删除对应的任务,当删除计划任务时,需要将 state 的值设置为 absent。
disabled:当计划任务有名称时,我们可以根据名称使对应的任务”失效”(注释掉对应的任务)。
backup:如果此参数的值设置为 yes,那么当修改或者删除对应的计划任务时,会先对计划任务进行备份,然后再对计划任务进行修改或者删除,cron 模块会在远程主机的 /tmp 目录下创建备份文件,以 crontab 开头并且随机加入一些字符,具体的备份文件名称会在返回信息的 backup_file 字段中看到,推荐将此此参数设置为 yes。

三、示例

示例1
在 ansible-demo3 主机上创建计划任务,任务名称为”crontab test”,任务于每天1点5分执行,任务内容为输出test字符。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='crontab test' minute=5 hour=1 job='echo test' "
[root@ansible-demo3 ~]# crontab -u root -l
#Ansible: crontab test
5 1 * * * echo test

示例2
在 ansible-demo3 主机上创建计划任务,任务名称为”crontab day test”,任务每3天执行一次,于执行当天的1点1分开始执行,任务内容为输出 test 字符。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='crontab day test' minute=1 hour=1 day=*/3 job='echo test' "
[root@ansible-demo3 ~]# crontab -u root -l
#Ansible: crontab test
5 1 * * * echo test
#Ansible: crontab day test
1 1 */3 * * echo test

示例3
在 ansible-demo3 主机上创建计划任务,任务名称为”special time test”,任务将在重启时执行,任务内容为输出 test 字符。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='special time test' special_time=reboot job='echo test' "
[root@ansible-demo3 ~]# crontab -u root -l
#Ansible: crontab test
5 1 * * * echo test
#Ansible: crontab day test
1 1 */3 * * echo test
#Ansible: special time test
@reboot echo test

示例4
由于”special time test”已经存在,所以,当我们再次操作同名的任务时,ansible 将会认为是修改原来的任务。执行如下命令,原计划任务会被修改,因为启用了 backup,所以任务在修改前会被备份。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='special time test' special_time=hourly job='echo test' backup=yes "

[

root@ansible-demo3 ~]# cat /tmp/crontabX6CMO1
#Ansible: crontab test
5 1 * * * echo test
#Ansible: crontab day test
1 1 */3 * * echo test
#Ansible: special time test
@reboot echo test

原来的”special time test”任务会变成如下设定:

#Ansible: special time test
@hourly echo test

示例5
任务”special time test”已经存在于 ansible-demo3 主机中,如果我们想要删除这个计划任务,可以执行如下命令,删除任务的同时可以进行备份。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='special time test' state=absent backup=yes "

命令执行后,从返回信息的 backup_file 字段中可以看到备份文件的远程主机中的位置。
示例6
默认操作的是 root 用户的计划任务,如果想要操作远程主机中其他用户的计划任务,可以指定要操作的用户。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a "user=ding name='special time test' special_time=hourly job='echo test' "
[root@ansible-demo3 ~]# crontab -u ding -l
#Ansible: special time test
@hourly echo test

示例7
上文已经创建了名称为 “crontab test” 的计划任务,如果我们想要暂时注释这个计划任务,可以使用如下命令。但是需要注意,在注释任务时,所有设定需要跟原设定保持一致,否则计划任务的设置将会发生改变,示例如下:
比如,我们想要将 crontab day test 这个任务注释掉,则需要使用如下命令。注意,最好与 backup 参数同时使用。

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='crontab day test' minute=1 hour=1 day=*/3 job='echo test' disabled=yes backup=yes"

执行上述命令后,对应的计划任务将会被注释:

[root@ansible-demo3 ~]# crontab -u root -l
#Ansible: crontab test
5 1 * * * echo test
#Ansible: crontab day test
#1 1 */3 * * echo test   

如果在使用 disabled 参数时,设置了错误的时间,那么对应任务被注释的同时,时间设定也会发生改变。比如,如果执行了如下命令:

[root@ansible-manager ~]# ansible ansible-demo3 -m cron -a " name='crontab day test' minute=55 job='echo test' disabled=yes backup=yes"

那么对应任务被注释的同时,还会进行如下设置:

[root@ansible-demo3 ~]# crontab -u root -l
#Ansible: crontab test
5 1 * * * echo test
#Ansible: crontab day test
#55 * * * * echo test 

如果忘记了任何时间设定,那么在任务被注释时,还会被设置为默认的时间设定,也就是 “* * * * *”。
所以,在使用 disabled 参数时,最好结合 backup 参数一起使用,万一一时大意,还有回旋的余地。

————Blueicex 2020/2/1 14:40 [email protected]

发布了55 篇原创文章 · 获赞 0 · 访问量 2017

猜你喜欢

转载自blog.csdn.net/blueicex2017/article/details/104134705
今日推荐