您的位置:首页 > 文旅 > 美景 > Ansible——cron模块

Ansible——cron模块

2024/12/23 10:46:05 来源:https://blog.csdn.net/Lzcsfg/article/details/139523159  浏览:    关键词:Ansible——cron模块

目录

参数总结

示例1:创建一个定时任务

示例2:删除一个定时任务

示例3:每周一早上 3 点清理临时文件

示例4:每小时运行一次日志轮转

示例5:为指定用户添加一个定时任务

Playbook (YAML 格式) 中管理定时任务。

示例1:创建一个定时任务

示例2:删除一个定时任务

示例3:每周一早上 3 点清理临时文件

示例4:每小时运行一次日志轮转

示例5:为指定用户添加一个定时任务

完整的 Playbook 示例


 

cron 模块是 Ansible 用于管理定时任务的模块。通过 cron 模块,我们可以方便地创建、修改和删除 Unix 系统上的定时任务记录。默认情况下每个任务都会被添加到用户的 crontab 文件中,这些任务会在同一个文件里。Crontab 文件是以用户为单位管理的,每个用户都有自己的 crontab 文件。默认是 root 用户。

参数总结

  1. name:

    • 描述:cron 作业的名称。
    • 类型:字符串
    • 必需:是
  2. minute:

    • 描述:cron 作业的分钟部分。
    • 类型:字符串
    • 默认值:*
  3. hour:

    • 描述:cron 作业的小时部分。
    • 类型:字符串
    • 默认值:*
  4. day:

    • 描述:cron 作业的日部分。
    • 类型:字符串
    • 默认值:*
  5. month:

    • 描述:cron 作业的月部分。
    • 类型:字符串
    • 默认值:*
  6. weekday:

    • 描述:cron 作业的星期部分。
    • 类型:字符串
    • 默认值:*
  7. job:

    • 描述:要执行的命令或脚本。
    • 类型:字符串
    • 必需:是
  8. user:

    • 描述:执行 cron 作业的用户。
    • 类型:字符串
    • 默认值:root
  9. state:

    • 描述:cron 作业的状态。
    • 可选值:present(默认,确保作业存在)、absent(确保作业不存在)
    • 类型:字符串

 

示例1:创建一个定时任务

添加一个每日凌晨 2 点运行的备份脚本任务:

ansible all -m cron -a "name='daily backup' minute='0' hour='2' job='/usr/local/bin/backup.sh'"

示例2:删除一个定时任务

删除名为 "daily backup" 的定时任务:

ansible all -m cron -a "name='daily backup' state='absent'"

示例3:每周一早上 3 点清理临时文件

添加一个每周一早上 3 点运行的临时文件清理任务:

ansible all -m cron -a "name='weekly temp files cleanup' minute='0' hour='3' weekday='1' job='/usr/bin/find /tmp -type f -atime +7 -delete'"

示例4:每小时运行一次日志轮转

添加一个每小时运行一次的日志轮转任务:

ansible all -m cron -a "name='hourly log rotation' minute='0' job='/usr/sbin/logrotate'"

示例5:为指定用户添加一个定时任务

为 username 用户添加一个每日凌晨 1 点运行的维护脚本任务:

ansible all -m cron -a "name='daily maintenance' minute='0' hour='1' job='/usr/local/bin/maintenance.sh' user='username'"

Playbook (YAML 格式) 中管理定时任务。

 

示例1:创建一个定时任务

下面的 Playbook 将在所有主机上添加一个每日凌晨 2 点运行备份脚本的任务:

---
- name: Setup cron job for daily backuphosts: alltasks:- name: Add daily backup cron jobcron:name: "daily backup"minute: "0"hour: "2"job: "/usr/local/bin/backup.sh"

示例2:删除一个定时任务

下面的 Playbook 将在所有主机上删除名为 "daily backup" 的定时任务:

---
- name: Remove the daily backup cron jobhosts: alltasks:- name: Remove daily backup cron jobcron:name: "daily backup"state: absent

示例3:每周一早上 3 点清理临时文件

这个 Playbook 将在每周一早上 3 点清理临时文件:

---
- name: Setup cron job to clean temp files weeklyhosts: alltasks:- name: Add weekly temp files cleanup cron jobcron:name: "weekly temp files cleanup"minute: "0"hour: "3"weekday: "1"  # 0 is Sunday, 1 is Monday, etc.job: "/usr/bin/find /tmp -type f -atime +7 -delete"

示例4:每小时运行一次日志轮转

这个 Playbook 将在所有主机上添加每小时运行一次日志轮转的任务:

---
- name: Setup cron job for hourly log rotationhosts: alltasks:- name: Add hourly log rotation cron jobcron:name: "hourly log rotation"minute: "0"job: "/usr/sbin/logrotate"

示例5:为指定用户添加一个定时任务

这个 Playbook 将为特定用户添加一个每日凌晨 1 点运行的维护脚本任务:

---
- name: Setup cron job for user-specific taskhosts: alltasks:- name: Add daily maintenance job for specific usercron:name: "daily maintenance"minute: "0"hour: "1"job: "/usr/local/bin/maintenance.sh"user: "username"

完整的 Playbook 示例

这是一个完整的 Playbook 示例,它展示了如何在同一个 Playbook 中添加、修改和删除多个定时任务:

---
- name: Cron jobs managementhosts: alltasks:- name: Add daily backup cron jobcron:name: "daily backup"minute: "0"hour: "2"job: "/usr/local/bin/backup.sh"- name: Add weekly temp files cleanup cron jobcron:name: "weekly temp files cleanup"minute: "0"hour: "3"weekday: "1"job: "/usr/bin/find /tmp -type f -atime +7 -delete"- name: Add hourly log rotation cron jobcron:name: "hourly log rotation"minute: "0"job: "/usr/sbin/logrotate"- name: Remove old backup cron jobcron:name: "old backup job"state: absent- name: Add daily maintenance job for specific usercron:name: "daily maintenance"minute: "0"hour: "1"job: "/usr/local/bin/maintenance.sh"user: "username"

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com