Note
This module is part of ansible-core and included in all Ansible installations. In most cases, you can use the short module name cron even without specifying the collections keyword. However, we recommend you use the Fully Qualified Collection Name (FQCN) ansible.builtin.cron for easy linking to the module documentation and to avoid conflicting with other collections that may have the same module name.
"#Ansible: <name>" corresponding to the name passed to the module, which is used by future ansible/module calls to find/check the state. The name parameter should be unique, and changing the name value will result in a new cron task being created (or a different one being removed).name parameter to find the environment variable definition line.%, they must be properly escaped.The below requirements are needed on the host that executes this module.
Parameter | Comments |
|---|---|
backup boolean | If set, create a backup of the crontab before it is modified. The location of the backup is returned in the Choices:
|
cron_file path | If specified, uses this file instead of an individual user’s crontab. The assumption is that this file is exclusively managed by the module, do not use if the file contains multiple entries, NEVER use for /etc/crontab. If this is a relative path, it is interpreted with respect to Many Linux distros expect (and some require) the filename portion to consist solely of upper- and lower-case letters, digits, underscores, and hyphens. Using this parameter requires you to specify the Either this parameter or |
day aliases: dom string | Day of the month the job should run ( Default: |
disabled boolean | If the job should be disabled (commented out) in the crontab. Only has effect if Choices:
|
env boolean | |
hour string | Hour when the job should run ( Default: |
insertafter string | Used with If specified, the environment variable will be inserted after the declaration of specified environment variable. |
insertbefore string | Used with If specified, the environment variable will be inserted before the declaration of specified environment variable. |
job aliases: value string | The command to execute or, if The command should not contain line breaks. Required if |
minute string | Minute when the job should run ( Default: |
month string | Month of the year the job should run ( Default: |
name string / required | Description of a crontab entry or, if This parameter is always required as of ansible-core 2.12. |
special_time string | Special time specification nickname. Choices:
|
state string | Whether to ensure the job or environment variable is present or absent. Choices:
|
user string | The specific user whose crontab should be modified. When unset, this parameter defaults to the current user. |
weekday aliases: dow string | Day of the week that the job should run ( Default: |
Attribute | Support | Description |
|---|---|---|
check_mode | Support: full | Can run in check_mode and return changed status prediction without modifying target, if not supported the action will be skipped. |
diff_mode | Support: full | Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode |
platform | Platform: posix | Target OS/families that can be operated against |
Note
- name: Ensure a job that runs at 2 and 5 exists. Creates an entry like "0 5,2 * * ls -alh > /dev/null"
ansible.builtin.cron:
name: "check dirs"
minute: "0"
hour: "5,2"
job: "ls -alh > /dev/null"
- name: 'Ensure an old job is no longer present. Removes any job that is prefixed by "#Ansible: an old job" from the crontab'
ansible.builtin.cron:
name: "an old job"
state: absent
- name: Creates an entry like "@reboot /some/job.sh"
ansible.builtin.cron:
name: "a job for reboot"
special_time: reboot
job: "/some/job.sh"
- name: Creates an entry like "PATH=/opt/bin" on top of crontab
ansible.builtin.cron:
name: PATH
env: yes
job: /opt/bin
- name: Creates an entry like "APP_HOME=/srv/app" and insert it after PATH declaration
ansible.builtin.cron:
name: APP_HOME
env: yes
job: /srv/app
insertafter: PATH
- name: Creates a cron file under /etc/cron.d
ansible.builtin.cron:
name: yum autoupdate
weekday: "2"
minute: "0"
hour: "12"
user: root
job: "YUMINTERACTIVE=0 /usr/sbin/yum-autoupdate"
cron_file: ansible_yum-autoupdate
- name: Removes a cron file from under /etc/cron.d
ansible.builtin.cron:
name: "yum autoupdate"
cron_file: ansible_yum-autoupdate
state: absent
- name: Removes "APP_HOME" environment variable from crontab
ansible.builtin.cron:
name: APP_HOME
env: yes
state: absent
© 2012–2018 Michael DeHaan
© 2018–2025 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/latest/collections/ansible/builtin/cron_module.html