Update indentation used in the code examples, unify empty lines (#65346)

This commit is contained in:
Wojciech Sciesinski 2019-12-10 16:55:51 +01:00 committed by ansibot
parent c5c1ad4fb8
commit 95aef88a45

View file

@ -18,18 +18,18 @@ Example project structure::
webservers.yml webservers.yml
fooservers.yml fooservers.yml
roles/ roles/
common/ common/
tasks/ tasks/
handlers/ handlers/
files/ files/
templates/ templates/
vars/ vars/
defaults/ defaults/
meta/ meta/
webservers/ webservers/
tasks/ tasks/
defaults/ defaults/
meta/ meta/
Roles expect files to be in certain directory names. Roles must include at least one of these directories, however it is perfectly fine to exclude any which are not being used. When in use, each directory must contain a ``main.yml`` file, which contains the relevant content: Roles expect files to be in certain directory names. Roles must include at least one of these directories, however it is perfectly fine to exclude any which are not being used. When in use, each directory must contain a ``main.yml`` file, which contains the relevant content:
@ -101,17 +101,16 @@ When used in this manner, the order of execution for your playbook is as follows
As of Ansible 2.4, you can now use roles inline with any other tasks using ``import_role`` or ``include_role``:: As of Ansible 2.4, you can now use roles inline with any other tasks using ``import_role`` or ``include_role``::
--- ---
- hosts: webservers - hosts: webservers
tasks: tasks:
- debug: - debug:
msg: "before we run our role" msg: "before we run our role"
- import_role: - import_role:
name: example name: example
- include_role: - include_role:
name: example name: example
- debug: - debug:
msg: "after we ran our role" msg: "after we ran our role"
When roles are defined in the classic manner, they are treated as static imports and processed during playbook parsing. When roles are defined in the classic manner, they are treated as static imports and processed during playbook parsing.
@ -121,7 +120,6 @@ When roles are defined in the classic manner, they are treated as static imports
The name used for the role can be a simple name (see :ref:`role_search_path` below), or it can be a fully qualified path:: The name used for the role can be a simple name (see :ref:`role_search_path` below), or it can be a fully qualified path::
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- role: '/path/to/my/roles/common' - role: '/path/to/my/roles/common'
@ -129,48 +127,44 @@ The name used for the role can be a simple name (see :ref:`role_search_path` bel
Roles can accept other keywords:: Roles can accept other keywords::
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- common - common
- role: foo_app_instance - role: foo_app_instance
vars: vars:
dir: '/opt/a' dir: '/opt/a'
app_port: 5000 app_port: 5000
- role: foo_app_instance - role: foo_app_instance
vars: vars:
dir: '/opt/b' dir: '/opt/b'
app_port: 5001 app_port: 5001
Or, using the newer syntax:: Or, using the newer syntax::
--- ---
- hosts: webservers - hosts: webservers
tasks: tasks:
- include_role: - include_role:
name: foo_app_instance name: foo_app_instance
vars: vars:
dir: '/opt/a' dir: '/opt/a'
app_port: 5000 app_port: 5000
... ...
You can conditionally import a role and execute its tasks:: You can conditionally import a role and execute its tasks::
--- ---
- hosts: webservers - hosts: webservers
tasks: tasks:
- include_role: - include_role:
name: some_role name: some_role
when: "ansible_facts['os_family'] == 'RedHat'" when: "ansible_facts['os_family'] == 'RedHat'"
Finally, you may wish to assign tags to the tasks inside the roles you specify. You can do:: Finally, you may wish to assign tags to the tasks inside the roles you specify. You can do::
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- role: foo - role: foo
@ -183,26 +177,26 @@ Finally, you may wish to assign tags to the tasks inside the roles you specify.
Or, again, using the newer syntax:: Or, again, using the newer syntax::
--- ---
- hosts: webservers - hosts: webservers
tasks: tasks:
- import_role: - import_role:
name: foo name: foo
tags: tags:
- bar - bar
- baz - baz
.. note:: .. note::
This *tags all of the tasks in that role with the tags specified*, appending to any tags that are specified inside the role. This *tags all of the tasks in that role with the tags specified*, appending to any tags that are specified inside the role.
On the other hand you might just want to tag the import of the role itself:: On the other hand you might just want to tag the import of the role itself::
---
- hosts: webservers - hosts: webservers
tasks: tasks:
- include_role: - include_role:
name: bar name: bar
tags: tags:
- foo - foo
.. note:: The tags in this example will *not* be added to tasks inside an ``include_role``, you can use a surrounding ``block`` directive to do both. .. note:: The tags in this example will *not* be added to tasks inside an ``include_role``, you can use a surrounding ``block`` directive to do both.
@ -216,8 +210,8 @@ Ansible will only allow a role to execute once, even if defined multiple times,
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- foo - foo
- foo - foo
Given the above, the role ``foo`` will only be run once. Given the above, the role ``foo`` will only be run once.
@ -231,10 +225,10 @@ Example 1 - passing different parameters::
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- role: foo - role: foo
vars: vars:
message: "first" message: "first"
- { role: foo, vars: { message: "second" } } - { role: foo, vars: { message: "second" } }
In this example, because each role definition has different parameters, ``foo`` will run twice. In this example, because each role definition has different parameters, ``foo`` will run twice.
@ -244,8 +238,8 @@ Example 2 - using ``allow_duplicates: true``::
--- ---
- hosts: webservers - hosts: webservers
roles: roles:
- foo - foo
- foo - foo
# roles/foo/meta/main.yml # roles/foo/meta/main.yml
--- ---
@ -284,7 +278,7 @@ Role dependencies allow you to automatically pull in other roles when using a ro
.. note:: .. note::
Role dependencies must use the classic role definition style. Role dependencies must use the classic role definition style.
Role dependencies are always executed before the role that includes them, and may be recursive. Dependencies also follow the duplication rules specified above. If another role also lists it as a dependency, it will not be run again based on the same rules given above. See :ref:`Galaxy role dependencies <galaxy_dependencies>` for more details. Role dependencies are always executed before the role that includes them, and may be recursive. Dependencies also follow the duplication rules specified above. If another role also lists it as a dependency, it will not be run again based on the same rules given above. See :ref:`Galaxy role dependencies <galaxy_dependencies>` for more details.
.. note:: .. note::
@ -294,25 +288,25 @@ For example, a role named ``car`` depends on a role named ``wheel`` as follows::
--- ---
dependencies: dependencies:
- role: wheel - role: wheel
vars: vars:
n: 1 n: 1
- role: wheel - role: wheel
vars: vars:
n: 2 n: 2
- role: wheel - role: wheel
vars: vars:
n: 3 n: 3
- role: wheel - role: wheel
vars: vars:
n: 4 n: 4
And the ``wheel`` role depends on two roles: ``tire`` and ``brake``. The ``meta/main.yml`` for wheel would then contain the following:: And the ``wheel`` role depends on two roles: ``tire`` and ``brake``. The ``meta/main.yml`` for wheel would then contain the following::
--- ---
dependencies: dependencies:
- role: tire - role: tire
- role: brake - role: brake
And the ``meta/main.yml`` for ``tire`` and ``brake`` would contain the following:: And the ``meta/main.yml`` for ``tire`` and ``brake`` would contain the following::
@ -354,14 +348,14 @@ Alongside the 'tasks' and 'handlers' structure of a role, add a directory named
Assuming you had this:: Assuming you had this::
roles/ roles/
my_custom_modules/ my_custom_modules/
library/ library/
module1 module1
module2 module2
The module will be usable in the role itself, as well as any roles that are called *after* this role, as follows:: The module will be usable in the role itself, as well as any roles that are called *after* this role, as follows::
---
- hosts: webservers - hosts: webservers
roles: roles:
- my_custom_modules - my_custom_modules
@ -373,10 +367,10 @@ This can also be used, with some limitations, to modify modules in Ansible's cor
The same mechanism can be used to embed and distribute plugins in a role, using the same schema. For example, for a filter plugin:: The same mechanism can be used to embed and distribute plugins in a role, using the same schema. For example, for a filter plugin::
roles/ roles/
my_custom_filter/ my_custom_filter/
filter_plugins filter_plugins
filter1 filter1
filter2 filter2
They can then be used in a template or a jinja template in any role called after 'my_custom_filter' They can then be used in a template or a jinja template in any role called after 'my_custom_filter'
@ -425,4 +419,3 @@ Read the `Ansible Galaxy documentation <https://galaxy.ansible.com/docs/>`_ page
Complete playbook files from the GitHub project source Complete playbook files from the GitHub project source
`Mailing List <https://groups.google.com/group/ansible-project>`_ `Mailing List <https://groups.google.com/group/ansible-project>`_
Questions? Help? Ideas? Stop by the list on Google Groups Questions? Help? Ideas? Stop by the list on Google Groups