How to pause a playbook execution for a certain amount of time with Ansible?
I'm going to show you a live Playbook with some simple Ansible code.
I'm Luca Berton and welcome to today's episode of Ansible Pilot
Ansible pause execution
Today we're talking about the Ansible module pause.
This module is also supported for Windows targets.
The full name is ansible.builtin.pause, which means that is part of the collection of modules "builtin" with Ansible and shipped with it.
The default behavior is to pause with a prompt.
Pauses playbook execution for a set amount of time, or until a prompt is acknowledged.
Parameters
minutesstring - a positive number of minutes
secondsstring - a positive number of seconds
promptstring - "Text message"
echoboolean - yes/no
All parameters are optional.
The default behavior is to pause with a prompt.
You could specify the amount of time using the parameters "minutes" and "seconds". Starting in Ansible 2.2, if you specify 0 or negative for minutes or seconds, it will wait for 1 second, previously it would wait indefinitely.
When minutes or seconds are specified, user input is not captured or echoed, regardless of the echo setting.
I'll cover the user input in another video.
## Playbook
Let's jump in a real-life Ansible Playbook to pause a playbook execution.
code
- pause.yml
``yaml
---
- name: pause module Playbook
hosts: all
vars:
wait_seconds: 10
tasks:
- name: pause for {{ wait_seconds | int }} second(s)
ansible.builtin.pause:
seconds: "{{ wait_seconds | int }}"
- name: message
ansible.builtin.debug:
msg: "The end"
`
output
`bash
$ ansible-playbook -i Playbook/inventory pause/pause.yml
PLAY [pause module Playbook] **
TASK [Gathering Facts]
ok: [demo.example.com]
TASK [pause for 10 second(s)] *
Pausing for 10 seconds
(ctrl+C then 'C' = continue early, ctrl+C then 'A' = abort)
ok: [demo.example.com]
TASK [message] **
ok: [demo.example.com] => {
"msg": "The end"
}
PLAY RECAP **
demo.example.com : ok=3 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
`
output with manual continue (CTRL+C and "C")
``bash
$ ansible-playbook -i Playbook/inventory pause/pause.yml
PLAY [pause module Playbook] **
TASK [Gathering Facts]
ok: [demo.example.com]
TASK [pause for 10 second(s)] *
Pausing for