Use async tasks for long running common tasks
Use async with poll: 0 for the long running common tasks including: - puppet host configuration - container-puppet generate config - container starting - container-puppet bootstrap tasks Executing the tasks in this manner and then polling for the results causes all of the tasks to be started in parallel across all the nodes, regardless of the number of ansible forks configured. The behavior will be that ansible will start the task on the first count of nodes that matches the configured forks value. Since poll:0, ansible will immediately move on to the next batch, etc. Effectively, all the tasks are started in parallel just as quickly as ansible can start them. The polling tasks (async_status) will then execute in parallel up to the configured number of forks. As tasks start to finish, ansible moves on to checking the status of the next batch (again, up to the configured number of forks). Since most nodes will configure around the same time, the polling tasks finish roughly at the same time (except for differences in roles, such as controllers taking much longer). This behavior results in a signifcant performance improvement at scale, or when deploying any number of nodes greater than the configured forks value. Instead of waiting for the first batch to fully complete, all the nodes are started in parallel. For example, if puppet host configuration usually takes 5 minutes per node, and there are 100 nodes, with 25 forks, previously this would have taken 20 minutes. With this patch, it would now take closer to 5 minutes for all 100 nodes, plus some overhead for polling. This more closely matches the behavior previously used with Heat, when all the nodes were operating in "pull" mode in parallel. Change-Id: I0c651d127cd2bb179f7592a0519a5fd5064faeb3
This commit is contained in:
parent
2a6336a742
commit
106ce3267f
@ -17,6 +17,8 @@
|
|||||||
- host_config
|
- host_config
|
||||||
|
|
||||||
- name: Run puppet host configuration for step {{ step }}
|
- name: Run puppet host configuration for step {{ step }}
|
||||||
|
async: 3600
|
||||||
|
poll: 0
|
||||||
when: enable_puppet|bool
|
when: enable_puppet|bool
|
||||||
shell: >-
|
shell: >-
|
||||||
set -o pipefail;
|
set -o pipefail;
|
||||||
@ -29,21 +31,32 @@
|
|||||||
{{ ansible_check_mode | bool | ternary('--hiera_config /etc/puppet/check-mode/hiera.yaml', '') }}
|
{{ ansible_check_mode | bool | ternary('--hiera_config /etc/puppet/check-mode/hiera.yaml', '') }}
|
||||||
/var/lib/tripleo-config/{{ ansible_check_mode | bool | ternary('check-mode/', '') }}puppet_step_config.pp
|
/var/lib/tripleo-config/{{ ansible_check_mode | bool | ternary('check-mode/', '') }}puppet_step_config.pp
|
||||||
2>&1 | logger -s -t puppet-user
|
2>&1 | logger -s -t puppet-user
|
||||||
changed_when: outputs.rc == 2
|
register: puppet_host_async_result
|
||||||
register: outputs
|
|
||||||
failed_when: false
|
|
||||||
no_log: true
|
no_log: true
|
||||||
tags:
|
tags:
|
||||||
- host_config
|
- host_config
|
||||||
check_mode: no
|
check_mode: no
|
||||||
|
|
||||||
|
- name: Wait for puppet host configuration to finish
|
||||||
|
async_status:
|
||||||
|
jid: "{{ puppet_host_async_result.ansible_job_id }}"
|
||||||
|
register: puppet_host_outputs
|
||||||
|
until: puppet_host_outputs.finished
|
||||||
|
retries: 1200
|
||||||
|
delay: 3
|
||||||
|
failed_when:
|
||||||
|
- (not puppet_host_outputs.finished) or (puppet_host_outputs.rc is defined and puppet_host_outputs.rc not in [0, 2])
|
||||||
|
tags:
|
||||||
|
- host_config
|
||||||
|
|
||||||
- name: "Debug output for task: Run puppet host configuration for step {{ step }}"
|
- name: "Debug output for task: Run puppet host configuration for step {{ step }}"
|
||||||
debug:
|
debug:
|
||||||
var: outputs.stdout_lines | default([]) | union(outputs.stderr_lines | default([]))
|
var: puppet_host_outputs.stdout_lines | default([]) | union(puppet_host_outputs.stderr_lines | default([]))
|
||||||
when:
|
when:
|
||||||
- enable_puppet | bool
|
- enable_puppet | bool
|
||||||
- outputs.rc is defined
|
- puppet_host_outputs.rc is defined
|
||||||
failed_when: outputs.rc not in [0, 2]
|
changed_when: puppet_host_outputs.rc == 2
|
||||||
|
failed_when: puppet_host_outputs.rc not in [0, 2]
|
||||||
tags:
|
tags:
|
||||||
- host_config
|
- host_config
|
||||||
ignore_errors: "{{ ansible_check_mode|bool }}"
|
ignore_errors: "{{ ansible_check_mode|bool }}"
|
||||||
@ -66,6 +79,8 @@
|
|||||||
######################################
|
######################################
|
||||||
|
|
||||||
- name: Run container-puppet tasks (generate config) during step {{ step }}
|
- name: Run container-puppet tasks (generate config) during step {{ step }}
|
||||||
|
async: 3600
|
||||||
|
poll: 0
|
||||||
shell: "{{ python_cmd }} /var/lib/container-puppet/container-puppet.py"
|
shell: "{{ python_cmd }} /var/lib/container-puppet/container-puppet.py"
|
||||||
environment:
|
environment:
|
||||||
NET_HOST: 'true'
|
NET_HOST: 'true'
|
||||||
@ -81,19 +96,27 @@
|
|||||||
CONTAINER_HEALTHCHECK_DISABLED: "{{ container_healthcheck_disabled }}"
|
CONTAINER_HEALTHCHECK_DISABLED: "{{ container_healthcheck_disabled }}"
|
||||||
SHORT_HOSTNAME: "{{ ansible_hostname }}"
|
SHORT_HOSTNAME: "{{ ansible_hostname }}"
|
||||||
when: step|int == 1
|
when: step|int == 1
|
||||||
changed_when: false
|
|
||||||
check_mode: no
|
check_mode: no
|
||||||
register: outputs
|
register: generate_config_async_result
|
||||||
failed_when: false
|
tags:
|
||||||
no_log: true
|
- container_config
|
||||||
|
|
||||||
|
- name: Wait for container-puppet tasks (generate config) to finish
|
||||||
|
async_status:
|
||||||
|
jid: "{{ generate_config_async_result.ansible_job_id }}"
|
||||||
|
register: generate_config_outputs
|
||||||
|
until: generate_config_outputs.finished
|
||||||
|
retries: 1200
|
||||||
|
delay: 3
|
||||||
|
when: step|int == 1
|
||||||
tags:
|
tags:
|
||||||
- container_config
|
- container_config
|
||||||
|
|
||||||
- name: "Debug output for task: Run container-puppet tasks (generate config) during step {{ step }}"
|
- name: "Debug output for task: Run container-puppet tasks (generate config) during step {{ step }}"
|
||||||
debug:
|
debug:
|
||||||
var: outputs.stdout_lines | default([]) | union(outputs.stderr_lines | default([]))
|
var: generate_config_outputs.stdout_lines | default([]) | union(generate_config_outputs.stderr_lines | default([]))
|
||||||
when: outputs.rc is defined
|
when: generate_config_outputs.rc is defined
|
||||||
failed_when: outputs.rc != 0
|
failed_when: generate_config_outputs.rc != 0
|
||||||
tags:
|
tags:
|
||||||
- container_config
|
- container_config
|
||||||
ignore_errors: "{{ ansible_check_mode|bool }}"
|
ignore_errors: "{{ ansible_check_mode|bool }}"
|
||||||
@ -135,6 +158,8 @@
|
|||||||
when: enable_paunch|default(true)
|
when: enable_paunch|default(true)
|
||||||
block:
|
block:
|
||||||
- name: Start containers for step {{ step }} using paunch
|
- name: Start containers for step {{ step }} using paunch
|
||||||
|
async: 3600
|
||||||
|
poll: 0
|
||||||
environment:
|
environment:
|
||||||
TRIPLEO_MINOR_UPDATE: '{{ tripleo_minor_update | default(false) }}'
|
TRIPLEO_MINOR_UPDATE: '{{ tripleo_minor_update | default(false) }}'
|
||||||
paunch:
|
paunch:
|
||||||
@ -146,16 +171,25 @@
|
|||||||
healthcheck_disabled: "{{ container_healthcheck_disabled | bool }}"
|
healthcheck_disabled: "{{ container_healthcheck_disabled | bool }}"
|
||||||
managed_by: "tripleo-{{ tripleo_role_name }}"
|
managed_by: "tripleo-{{ tripleo_role_name }}"
|
||||||
debug: "{{ enable_debug | bool }}"
|
debug: "{{ enable_debug | bool }}"
|
||||||
register: outputs
|
register: start_containers_async_result
|
||||||
failed_when: false
|
tags:
|
||||||
|
- container_startup_configs
|
||||||
|
|
||||||
|
- name: Wait for containers to start for step {{ step }} using paunch
|
||||||
|
async_status:
|
||||||
|
jid: "{{ start_containers_async_result.ansible_job_id }}"
|
||||||
|
register: start_containers_outputs
|
||||||
|
until: start_containers_outputs.finished
|
||||||
|
retries: 1200
|
||||||
|
delay: 3
|
||||||
tags:
|
tags:
|
||||||
- container_startup_configs
|
- container_startup_configs
|
||||||
|
|
||||||
- name: "Debug output for task: Start containers for step {{ step }}"
|
- name: "Debug output for task: Start containers for step {{ step }}"
|
||||||
debug:
|
debug:
|
||||||
var: outputs.stdout_lines | default([]) | union(outputs.stderr_lines | default([]))
|
var: start_containers_outputs.stdout_lines | default([]) | union(start_containers_outputs.stderr_lines | default([]))
|
||||||
when: outputs.rc is defined
|
when: start_containers_outputs.rc is defined
|
||||||
failed_when: outputs.rc != 0
|
failed_when: start_containers_outputs.rc != 0
|
||||||
tags:
|
tags:
|
||||||
- container_startup_configs
|
- container_startup_configs
|
||||||
|
|
||||||
@ -213,6 +247,8 @@
|
|||||||
when: host_container_puppet_tasks is defined
|
when: host_container_puppet_tasks is defined
|
||||||
|
|
||||||
- name: Run container-puppet tasks (bootstrap tasks) for step {{ step }}
|
- name: Run container-puppet tasks (bootstrap tasks) for step {{ step }}
|
||||||
|
async: 3600
|
||||||
|
poll: 0
|
||||||
shell: "{{ python_cmd }} /var/lib/container-puppet/container-puppet.py"
|
shell: "{{ python_cmd }} /var/lib/container-puppet/container-puppet.py"
|
||||||
environment:
|
environment:
|
||||||
CONFIG: /var/lib/container-puppet/{{ ansible_check_mode | bool | ternary('check-mode/', '') }}container-puppet-tasks{{ step }}.json
|
CONFIG: /var/lib/container-puppet/{{ ansible_check_mode | bool | ternary('check-mode/', '') }}container-puppet-tasks{{ step }}.json
|
||||||
@ -226,17 +262,28 @@
|
|||||||
SHORT_HOSTNAME: "{{ ansible_hostname }}"
|
SHORT_HOSTNAME: "{{ ansible_hostname }}"
|
||||||
PROCESS_COUNT: "{{ docker_puppet_process_count }}"
|
PROCESS_COUNT: "{{ docker_puppet_process_count }}"
|
||||||
when: host_container_puppet_tasks is defined
|
when: host_container_puppet_tasks is defined
|
||||||
changed_when: false
|
register: bootstrap_tasks_async_result
|
||||||
register: outputs
|
|
||||||
failed_when: false
|
|
||||||
no_log: true
|
no_log: true
|
||||||
tags:
|
tags:
|
||||||
- container_config_tasks
|
- container_config_tasks
|
||||||
|
|
||||||
|
- name: Wait for container-puppet tasks (bootstrap tasks) for step {{ step }} to finish
|
||||||
|
async_status:
|
||||||
|
jid: "{{ bootstrap_tasks_async_result.ansible_job_id }}"
|
||||||
|
register: bootstrap_tasks_outputs
|
||||||
|
until: bootstrap_tasks_outputs.finished
|
||||||
|
retries: 1200
|
||||||
|
delay: 3
|
||||||
|
when: host_container_puppet_tasks is defined
|
||||||
|
tags:
|
||||||
|
- container_config_tasks
|
||||||
|
|
||||||
- name: "Debug output for task: Run container-puppet tasks (bootstrap tasks) for step {{ step }}"
|
- name: "Debug output for task: Run container-puppet tasks (bootstrap tasks) for step {{ step }}"
|
||||||
debug:
|
debug:
|
||||||
var: outputs.stdout_lines | default([]) | union(outputs.stderr_lines | default([]))
|
var: bootstrap_tasks_outputs.stdout_lines | default([]) | union(bootstrap_tasks_outputs.stderr_lines | default([]))
|
||||||
when: outputs.rc is defined
|
when:
|
||||||
failed_when: outputs.rc != 0
|
- host_container_puppet_tasks is defined
|
||||||
|
- bootstrap_tasks_outputs.rc is defined
|
||||||
|
failed_when: bootstrap_tasks_outputs.rc != 0
|
||||||
tags:
|
tags:
|
||||||
- container_config_tasks
|
- container_config_tasks
|
||||||
|
Loading…
Reference in New Issue
Block a user