b685ac44e0
Including tasks has a performance penalty when compared with importing tasks. If the include has a condition associated with it, then the overhead of the include may be lower than the overhead of skipping all imported tasks. For unconditionally included tasks, switching to import_tasks provides a clear benefit. Benchmarking of include vs. import is available at [1]. This change switches from include_tasks to import_tasks where there is no condition applied to the include. [1] https://github.com/stackhpc/ansible-scaling/blob/master/doc/include-and-import.md#task-include-and-import Partially-Implements: blueprint performance-improvements Change-Id: Ia45af4a198e422773d9f009c7f7b2e32ce9e3b97
102 lines
3.6 KiB
YAML
102 lines
3.6 KiB
YAML
---
|
|
- name: Prepare Swift containers list
|
|
set_fact:
|
|
swift_containers:
|
|
- { name: swift_account_server, group: swift-account-server }
|
|
- { name: swift_account_auditor, group: swift-account-server }
|
|
- { name: swift_account_replicator, group: swift-account-server }
|
|
- { name: swift_account_reaper, group: swift-account-server }
|
|
- { name: swift_rsyncd, group: swift-account-server }
|
|
- { name: swift_container_server, group: swift-container-server }
|
|
- { name: swift_container_auditor, group: swift-container-server }
|
|
- { name: swift_container_replicator, group: swift-container-server }
|
|
- { name: swift_container_updater, group: swift-container-server }
|
|
- { name: swift_rsyncd, group: swift-container-server }
|
|
- { name: swift_object_server, group: swift-object-server }
|
|
- { name: swift_object_auditor, group: swift-object-server }
|
|
- { name: swift_object_replicator, group: swift-object-server }
|
|
- { name: swift_object_updater, group: swift-object-server }
|
|
- { name: swift_object_expirer, group: swift-object-server }
|
|
- { name: swift_rsyncd, group: swift-object-server }
|
|
- { name: swift_proxy_server, group: swift-proxy-server }
|
|
swift_replication_server_containers:
|
|
- { name: swift_account_replication_server, group: swift-account-server }
|
|
- { name: swift_container_replication_server, group: swift-container-server }
|
|
- { name: swift_object_replication_server, group: swift-object-server }
|
|
|
|
- name: Add _replication_server containers to the list
|
|
set_fact:
|
|
swift_containers: "{{ swift_containers + swift_replication_server_containers }}"
|
|
when: swift_has_replication_network
|
|
|
|
- name: Ensuring the containers up
|
|
become: true
|
|
kolla_docker:
|
|
name: "{{ item.name }}"
|
|
action: "get_container_state"
|
|
register: container_state
|
|
failed_when: not container_state.Running
|
|
when: inventory_hostname in groups[item.group]
|
|
with_items:
|
|
- "{{ swift_containers }}"
|
|
|
|
- import_tasks: config.yml
|
|
|
|
- name: Check the configs
|
|
become: true
|
|
command: docker exec -u root {{ item.name }} /usr/local/bin/kolla_set_configs --check
|
|
changed_when: false
|
|
failed_when: false
|
|
register: check_results
|
|
when: inventory_hostname in groups[item.group]
|
|
with_items:
|
|
- "{{ swift_containers }}"
|
|
|
|
# NOTE(jeffrey4l): when config_strategy == 'COPY_ALWAYS'
|
|
# and container env['KOLLA_CONFIG_STRATEGY'] == 'COPY_ONCE',
|
|
# just remove the container and start again
|
|
- name: Containers config strategy
|
|
become: true
|
|
kolla_docker:
|
|
name: "{{ item.name }}"
|
|
action: "get_container_env"
|
|
register: container_envs
|
|
when: inventory_hostname in groups[item.group]
|
|
with_items:
|
|
- "{{ swift_containers }}"
|
|
|
|
- name: Remove the containers
|
|
become: true
|
|
kolla_docker:
|
|
name: "{{ item[0]['name'] }}"
|
|
action: "remove_container"
|
|
register: remove_containers
|
|
when:
|
|
- inventory_hostname in groups[item[0]['group']]
|
|
- config_strategy == "COPY_ONCE" or item[1]['KOLLA_CONFIG_STRATEGY'] == 'COPY_ONCE'
|
|
- item[2]['rc'] == 1
|
|
with_together:
|
|
- "{{ swift_containers }}"
|
|
- "{{ container_envs.results }}"
|
|
- "{{ check_results.results }}"
|
|
|
|
- include_tasks: start.yml
|
|
vars:
|
|
run_start_swift_proxy_server: "yes"
|
|
when: remove_containers.changed
|
|
|
|
- name: Restart containers
|
|
become: true
|
|
kolla_docker:
|
|
name: "{{ item[0]['name'] }}"
|
|
action: "restart_container"
|
|
when:
|
|
- inventory_hostname in groups[item[0]['group']]
|
|
- config_strategy == 'COPY_ALWAYS'
|
|
- item[1]['KOLLA_CONFIG_STRATEGY'] != 'COPY_ONCE'
|
|
- item[2]['rc'] == 1
|
|
with_together:
|
|
- "{{ swift_containers }}"
|
|
- "{{ container_envs.results }}"
|
|
- "{{ check_results.results }}"
|