diff --git a/downstream/assemblies/playbooks/assembly-playbooks-reference-intro.adoc b/downstream/assemblies/playbooks/assembly-playbooks-reference-intro.adoc new file mode 100644 index 000000000..0493b8f2c --- /dev/null +++ b/downstream/assemblies/playbooks/assembly-playbooks-reference-intro.adoc @@ -0,0 +1,43 @@ +[id="assembly-playbooks-reference-intro"] + += Introduction + +An Ansible Playbook is a blueprint for automation tasks, which are actions executed with limited manual effort across an inventory of solutions. +Playbooks tell Ansible what to do on which devices. +Instead of manually applying the same action to hundreds or thousands of similar technologies across IT environments, executing a playbook automatically completes the same action for the specified type of inventory, such as a set of routers. + +Playbooks are regularly used to automate IT infrastructure—such as operating systems and Kubernetes platforms, networks, security systems, and code repositories like GitHub. + +You can use playbooks to program applications, services, server nodes, and other devices, without the manual overhead of creating everything from scratch. + +Playbooks, and the conditions, variables, and tasks within them, can be saved, shared, or reused indefinitely. + +This makes it easier for you to codify operational knowledge and ensure that the same actions are performed consistently. + +[discrete] +== Task execution + +By default, Ansible executes each task in order, one at a time, against all machines matched by the host pattern. +Each task executes a module with specific arguments. +When a task has been executed on all target machines, Ansible moves on to the next task. +You can use xref:[strategies] to change this default behavior. + +Within each play, Ansible applies the same task directives to all hosts. +If a task fails on a host, Ansible takes that host out of the rotation for the rest of the playbook. + +When you run a playbook, Ansible returns information about connections, the name lines of all your plays and tasks, whether each task has succeeded or failed on each machine, and whether each task has made a change on each machine. + +At the bottom of the playbook execution, Ansible provides a summary of the nodes that were targeted and how they performed. + +General failures and fatal “unreachable” communication attempts are kept separate in the counts. + +[discrete] +== Desired state and idempotency + +Most Ansible modules check whether the desired final state has already been achieved, and exit without performing any actions if that state has been achieved, so that repeating the task does not change the final state. +Modules that behave this way are often called 'idempotent'. +Whether you run a playbook once, or multiple times, the outcome should be the same. +However, not all playbooks and not all modules behave this way. +If you are unsure, test your playbooks in a sandbox environment before running them multiple times in production. + +This guide describes the commands, techniques and aspects of use that you can use to make your playbooks more efficient. diff --git a/downstream/modules/playbooks/con-playbooks-desired-state-idempotent.adoc b/downstream/modules/playbooks/con-playbooks-desired-state-idempotent.adoc new file mode 100644 index 000000000..de9eeacb3 --- /dev/null +++ b/downstream/modules/playbooks/con-playbooks-desired-state-idempotent.adoc @@ -0,0 +1,9 @@ +[id="con-playbooks-desired-state-idempotent"] + += Desired state and idempotency + +Most Ansible modules check whether the desired final state has already been achieved, and exit without performing any actions if that state has been achieved, so that repeating the task does not change the final state. +Modules that behave this way are often called 'idempotent'. +Whether you run a playbook once, or multiple times, the outcome should be the same. +However, not all playbooks and not all modules behave this way. +If you are unsure, test your playbooks in a sandbox environment before running them multiple times in production. diff --git a/downstream/modules/playbooks/con-playbooks-task-execution.adoc b/downstream/modules/playbooks/con-playbooks-task-execution.adoc new file mode 100644 index 000000000..e39c37ebd --- /dev/null +++ b/downstream/modules/playbooks/con-playbooks-task-execution.adoc @@ -0,0 +1,17 @@ +[id="con-playbooks-task-execution"] + += Task execution + +By default, Ansible executes each task in order, one at a time, against all machines matched by the host pattern. +Each task executes a module with specific arguments. +When a task has been executed on all target machines, Ansible moves on to the next task. +You can use xref:[strategies] to change this default behavior. + +Within each play, Ansible applies the same task directives to all hosts. +If a task fails on a host, Ansible takes that host out of the rotation for the rest of the playbook. + +When you run a playbook, Ansible returns information about connections, the name lines of all your plays and tasks, whether each task has succeeded or failed on each machine, and whether each task has made a change on each machine. + +At the bottom of the playbook execution, Ansible provides a summary of the nodes that were targeted and how they performed. + +General failures and fatal “unreachable” communication attempts are kept separate in the counts. diff --git a/downstream/titles/playbooks/playbooks-reference/master.adoc b/downstream/titles/playbooks/playbooks-reference/master.adoc index f07f46dc3..384013823 100644 --- a/downstream/titles/playbooks/playbooks-reference/master.adoc +++ b/downstream/titles/playbooks/playbooks-reference/master.adoc @@ -17,4 +17,4 @@ This guide provides a reference for the differing approaches to the creating of include::aap-common/making-open-source-more-inclusive.adoc[leveloffset=+1] include::{DocumentationFeedback}[leveloffset=+1] -include::playbooks/assembly-reference-test.adoc[leveloffset=+1] \ No newline at end of file +include::playbooks/assembly-playbooks-reference-intro.adoc[leveloffset=+1] \ No newline at end of file