Skip to content
Snippets Groups Projects
Commit 692c6986 authored by Jenkins's avatar Jenkins Committed by Gerrit Code Review
Browse files

Merge "Optimize reconfigure action for rally"

parents f2f30b4a 9af94ff0
No related branches found
No related tags found
No related merge requests found
--- ---
project_name: "rally" project_name: "rally"
rally_services:
rally:
container_name: "rally"
image: "{{ rally_image_full }}"
enabled: true
group: "rally"
volumes:
- "{{ node_config_directory }}/rally/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla/"
######## ########
# Docker # Docker
......
- name: Restart rally container
vars:
service_name: "rally"
service: "{{ rally_services[service_name] }}"
config_json: "{{ rally_config_jsons.results|selectattr('item.key', 'equalto', service_name)|first }}"
rally_conf: "{{ rally_confs.results|selectattr('item.key', 'equalto', service_name)|first }}"
policy_json: "{{ rally_policy_jsons.results|selectattr('item.key', 'equalto', service_name)|first }}"
rally_container: "{{ check_rally_containers.results|selectattr('item.key', 'equalto', service_name)|first }}"
kolla_docker:
action: "recreate_or_restart_container"
common_options: "{{ docker_common_options }}"
name: "{{ service.container_name }}"
image: "{{ service.image }}"
privileged: "{{ service.privileged | default(False) }}"
volumes: "{{ service.volumes|reject('equalto', '')|list }}"
when:
- action != "config"
- inventory_hostname in groups[service.group]
- service.enabled | bool
- config_json.changed | bool
or rally_conf.changed | bool
or policy_json.changed | bool
or rally_container.changed | bool
--- ---
- name: Running rally bootstrap container - name: Running rally bootstrap container
vars:
rally: "{{ rally_services['rally'] }}"
kolla_docker: kolla_docker:
action: "start_container" action: "start_container"
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
...@@ -7,14 +9,11 @@ ...@@ -7,14 +9,11 @@
environment: environment:
KOLLA_BOOTSTRAP: KOLLA_BOOTSTRAP:
KOLLA_CONFIG_STRATEGY: "{{ config_strategy }}" KOLLA_CONFIG_STRATEGY: "{{ config_strategy }}"
image: "{{ rally_image_full }}" image: "{{ rally.image }}"
labels: labels:
BOOTSTRAP: BOOTSTRAP:
name: "bootstrap_rally" name: "bootstrap_rally"
restart_policy: "never" restart_policy: "never"
volumes: volumes: "{{ rally.volumes }}"
- "{{ node_config_directory }}/rally/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla/"
run_once: True run_once: True
delegate_to: "{{ groups['rally'][0] }}" delegate_to: "{{ groups[rally.group][0] }}"
--- ---
- name: Ensuring config directories exist - name: Ensuring config directories exist
file: file:
path: "{{ node_config_directory }}/{{ item }}" path: "{{ node_config_directory }}/{{ item.key }}"
state: "directory" state: "directory"
recurse: yes recurse: yes
with_items: when: inventory_hostname in groups[item.value.group]
- "rally" with_dict: "{{ rally_services }}"
- name: Copying over config.json files for services - name: Copying over config.json files for services
template: template:
src: "{{ item }}.json.j2" src: "{{ item.key }}.json.j2"
dest: "{{ node_config_directory }}/{{ item }}/config.json" dest: "{{ node_config_directory }}/{{ item.key }}/config.json"
with_items: register: rally_config_jsons
- "rally" when:
- item.value.enabled | bool
- inventory_hostname in groups[item.value.group]
with_dict: "{{ rally_services }}"
notify:
- Restart rally container
- name: Copying over rally.conf - name: Copying over rally.conf
merge_configs: merge_configs:
vars: vars:
project_name: "rally" service_name: "{{ item.key }}"
sources: sources:
- "{{ role_path }}/templates/rally.conf.j2" - "{{ role_path }}/templates/rally.conf.j2"
- "{{ node_custom_config }}/rally.conf" - "{{ node_custom_config }}/rally.conf"
dest: "{{ node_config_directory }}/{{ item }}/rally.conf" dest: "{{ node_config_directory }}/{{ item.key }}/{{ item.key }}.conf"
with_items: register: rally_confs
- "rally" when:
- item.value.enabled | bool
- inventory_hostname in groups[item.value.group]
with_dict: "{{ rally_services }}"
notify:
- Restart rally container
- name: Check if policies shall be overwritten - name: Check if policies shall be overwritten
local_action: stat path="{{ node_custom_config }}/rally/policy.json" local_action: stat path="{{ node_custom_config }}/rally/policy.json"
...@@ -32,6 +42,28 @@ ...@@ -32,6 +42,28 @@
- name: Copying over existing policy.json - name: Copying over existing policy.json
template: template:
src: "{{ node_custom_config }}/rally/policy.json" src: "{{ node_custom_config }}/rally/policy.json"
dest: "{{ node_config_directory }}/rally/policy.json" dest: "{{ node_config_directory }}/{{ item.key }}/policy.json"
register: rally_policy_jsons
when:
- rally_policy.stat.exists
- inventory_hostname in groups[item.value.group]
- item.value.enabled | bool
with_dict: "{{ rally_services }}"
notify:
- Restart rally container
- name: Check rally containers
kolla_docker:
action: "compare_container"
common_options: "{{ docker_common_options }}"
name: "{{ item.value.container_name }}"
image: "{{ item.value.image }}"
volumes: "{{ item.value.volumes }}"
register: check_rally_containers
when: when:
rally_policy.stat.exists - action != "config"
- inventory_hostname in groups[item.value.group]
- item.value.enabled | bool
with_dict: "{{ rally_services }}"
notify:
- Restart rally container
--- ---
- include: config.yml - include: config.yml
- include: bootstrap.yml - include: bootstrap.yml
- include: start.yml
- name: Flush handlers
meta: flush_handlers
...@@ -3,4 +3,8 @@ ...@@ -3,4 +3,8 @@
kolla_docker: kolla_docker:
action: "pull_image" action: "pull_image"
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
image: "{{ rally_image_full }}" image: "{{ item.value.image }}"
when:
- inventory_hostname in groups[item.value.group]
- item.value.enabled | bool
with_dict: "{{ rally_services }}"
--- ---
- name: Ensuring the containers up - include: deploy.yml
kolla_docker:
name: "{{ item.name }}"
action: "get_container_state"
register: container_state
failed_when: container_state.Running == false
when: inventory_hostname in groups[item.group]
with_items:
- { name: rally, group: rally }
- include: config.yml
- name: Check the configs
command: docker exec {{ 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:
- { name: rally, group: rally }
# 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
kolla_docker:
name: "{{ item.name }}"
action: "get_container_env"
register: container_envs
when: inventory_hostname in groups[item.group]
with_items:
- { name: rally, group: rally }
- name: Remove the containers
kolla_docker:
name: "{{ item[0]['name'] }}"
action: "remove_container"
register: remove_containers
when:
- config_strategy == "COPY_ONCE" or item[1]['KOLLA_CONFIG_STRATEGY'] == 'COPY_ONCE'
- item[2]['rc'] == 1
- inventory_hostname in groups[item[0]['group']]
with_together:
- [{ name: rally, group: rally }]
- "{{ container_envs.results }}"
- "{{ check_results.results }}"
- include: start.yml
when: remove_containers.changed
- name: Restart containers
kolla_docker:
name: "{{ item[0]['name'] }}"
action: "restart_container"
when:
- config_strategy == 'COPY_ALWAYS'
- item[1]['KOLLA_CONFIG_STRATEGY'] != 'COPY_ONCE'
- item[2]['rc'] == 1
- inventory_hostname in groups[item[0]['group']]
with_together:
- [{ name: rally, group: rally }]
- "{{ container_envs.results }}"
- "{{ check_results.results }}"
---
- name: Starting rally container
kolla_docker:
action: "start_container"
common_options: "{{ docker_common_options }}"
image: "{{ rally_image_full }}"
name: "rally"
volumes:
- "{{ node_config_directory }}/rally/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla/"
...@@ -3,4 +3,5 @@ ...@@ -3,4 +3,5 @@
- include: bootstrap_service.yml - include: bootstrap_service.yml
- include: start.yml - name: Flush handlers
meta: flush_handlers
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment