Merge "[Train] Fix Tacker config for the local Glance store"

This commit is contained in:
Zuul 2019-12-03 10:21:33 +00:00 committed by Gerrit Code Review
commit f8862c6cc2
7 changed files with 63 additions and 13 deletions

View File

@ -5,7 +5,7 @@ tacker_services:
tacker-server: tacker-server:
container_name: "tacker_server" container_name: "tacker_server"
group: "tacker-server" group: "tacker-server"
host_in_groups: "{{ inventory_hostname in groups['tacker-server'] }}" host_in_groups: "{{ inventory_hostname in tacker_hosts }}"
enabled: true enabled: true
image: "{{ tacker_server_image_full }}" image: "{{ tacker_server_image_full }}"
volumes: "{{ tacker_server_default_volumes + tacker_server_extra_volumes }}" volumes: "{{ tacker_server_default_volumes + tacker_server_extra_volumes }}"
@ -16,15 +16,17 @@ tacker_services:
mode: "http" mode: "http"
external: false external: false
port: "{{ tacker_server_port }}" port: "{{ tacker_server_port }}"
custom_member_list: "{{ tacker_haproxy_members.split(';') }}"
tacker_server_external: tacker_server_external:
enabled: "{{ enable_tacker }}" enabled: "{{ enable_tacker }}"
mode: "http" mode: "http"
external: true external: true
port: "{{ tacker_server_port }}" port: "{{ tacker_server_port }}"
custom_member_list: "{{ tacker_haproxy_members.split(';') }}"
tacker-conductor: tacker-conductor:
container_name: "tacker_conductor" container_name: "tacker_conductor"
group: "tacker-conductor" group: "tacker-conductor"
host_in_groups: "{{ inventory_hostname in tacker_conductor_hosts }}" host_in_groups: "{{ inventory_hostname in tacker_hosts }}"
enabled: true enabled: true
image: "{{ tacker_conductor_image_full }}" image: "{{ tacker_conductor_image_full }}"
volumes: "{{ tacker_conductor_default_volumes + tacker_conductor_extra_volumes }}" volumes: "{{ tacker_conductor_default_volumes + tacker_conductor_extra_volumes }}"
@ -59,19 +61,27 @@ tacker_server_default_volumes:
- "{{ kolla_dev_repos_directory ~ '/tacker/tacker:/var/lib/kolla/venv/lib/python2.7/site-packages/tacker' if tacker_dev_mode | bool else '' }}" - "{{ kolla_dev_repos_directory ~ '/tacker/tacker:/var/lib/kolla/venv/lib/python2.7/site-packages/tacker' if tacker_dev_mode | bool else '' }}"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
# NOTE(yoctozepto): Starting in Train, this volume must be shared
# between all instances of both Tacker services (Server, Conductor)
- "kolla_tacker_csar_files:/var/lib/tacker/csar_files/"
tacker_conductor_default_volumes: tacker_conductor_default_volumes:
- "{{ node_config_directory }}/tacker-conductor/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/tacker-conductor/:{{ container_config_directory }}/:ro"
- "{{ kolla_dev_repos_directory ~ '/tacker/tacker:/var/lib/kolla/venv/lib/python2.7/site-packages/tacker' if tacker_dev_mode | bool else '' }}" - "{{ kolla_dev_repos_directory ~ '/tacker/tacker:/var/lib/kolla/venv/lib/python2.7/site-packages/tacker' if tacker_dev_mode | bool else '' }}"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
- "kolla_tacker_vnfpackages:/var/lib/tacker/vnfpackages/" - "kolla_tacker_vnfpackages:/var/lib/tacker/vnfpackages/"
# NOTE(yoctozepto): Starting in Train, this volume must be shared
# between all instances of both Tacker services (Server, Conductor)
- "kolla_tacker_csar_files:/var/lib/tacker/csar_files/" - "kolla_tacker_csar_files:/var/lib/tacker/csar_files/"
tacker_extra_volumes: "{{ default_extra_volumes }}" tacker_extra_volumes: "{{ default_extra_volumes }}"
tacker_server_extra_volumes: "{{ tacker_extra_volumes }}" tacker_server_extra_volumes: "{{ tacker_extra_volumes }}"
tacker_conductor_extra_volumes: "{{ tacker_extra_volumes }}" tacker_conductor_extra_volumes: "{{ tacker_extra_volumes }}"
tacker_conductor_hosts: "{{ [groups['tacker-conductor']|first] }}" # NOTE(yoctozepto): Starting in Train, this variable is used to co-locate all
# Tacker services on one host since we do not provide shared filesystem
# to satisfy kolla_tacker_csar_files volume needs.
tacker_hosts: "{{ [groups['tacker']|first] }}"
#################### ####################
# OpenStack # OpenStack
@ -120,3 +130,8 @@ tacker_ks_users:
user: "{{ tacker_keystone_user }}" user: "{{ tacker_keystone_user }}"
password: "{{ tacker_keystone_password }}" password: "{{ tacker_keystone_password }}"
role: "admin" role: "admin"
####################
# HAProxy
####################
tacker_haproxy_members: "{% for host in tacker_hosts %}server {{ hostvars[host]['ansible_hostname'] }} {{ 'api' | kolla_address(host) }}:{{ tacker_server_port }} check inter 2000 rise 2 fall 5;{% endfor %}"

View File

@ -1,4 +1,35 @@
--- ---
- name: Warn about Train upgrade
debug:
msg: >-
In Train, Tacker started using local filesystem to store VNF
packages and CSAR files.
Kolla Ansible provides no shared filesystem capabilities, hence only
one instance of each Tacker service is deployed and all on the same host.
Previous multinode deployments will be descaled when running upgrade.
- name: Stop and remove extra tacker-conductor containers
vars:
service_name: "tacker-conductor"
service: "{{ tacker_services[service_name] }}"
become: true
kolla_docker:
action: "stop_and_remove_container"
name: "{{ service.container_name }}"
when:
- inventory_hostname not in tacker_hosts
- name: Stop and remove extra tacker-server containers
vars:
service_name: "tacker-server"
service: "{{ tacker_services[service_name] }}"
become: true
kolla_docker:
action: "stop_and_remove_container"
name: "{{ service.container_name }}"
when:
- inventory_hostname not in tacker_hosts
- include_tasks: config.yml - include_tasks: config.yml
- include_tasks: bootstrap_service.yml - include_tasks: bootstrap_service.yml

View File

@ -22,13 +22,11 @@
}, },
{ {
"path": "/var/lib/tacker/vnfpackages", "path": "/var/lib/tacker/vnfpackages",
"owner": "tacker:tacker", "owner": "tacker:tacker"
"recurse": true
}, },
{ {
"path": "/var/lib/tacker/csar_files", "path": "/var/lib/tacker/csar_files",
"owner": "tacker:tacker", "owner": "tacker:tacker"
"recurse": true
} }
] ]
} }

View File

@ -19,6 +19,10 @@
"path": "/var/log/kolla/tacker", "path": "/var/log/kolla/tacker",
"owner": "tacker:tacker", "owner": "tacker:tacker",
"recurse": true "recurse": true
},
{
"path": "/var/lib/tacker/csar_files",
"owner": "tacker:tacker"
} }
] ]
} }

View File

@ -67,3 +67,6 @@ driver = noop
[oslo_policy] [oslo_policy]
policy_file = {{ tacker_policy_file }} policy_file = {{ tacker_policy_file }}
{% endif %} {% endif %}
[glance_store]
filesystem_store_datadir = /var/lib/tacker/csar_files

View File

@ -64,10 +64,10 @@ In order to enable them, you need to edit the file
.. warning:: .. warning::
In Train, Tacker Conductor started using local filesystem to store VNF In Train, Tacker started using local filesystem to store VNF
packages and CSAR files. packages and CSAR files.
Kolla Ansible provides no shared filesystem capabilities, hence only Kolla Ansible provides no shared filesystem capabilities, hence only
one instance of Tacker Conductor is deployed. one instance of each Tacker service is deployed and all on the same host.
Deploy tacker and related services. Deploy tacker and related services.

View File

@ -1,9 +1,8 @@
--- ---
upgrade: upgrade:
- | - |
In Train, Tacker Conductor started using local filesystem to store VNF In Train, Tacker started using local filesystem to store VNF
packages and CSAR files. packages and CSAR files.
Kolla Ansible provides no shared filesystem capabilities, hence only Kolla Ansible provides no shared filesystem capabilities, hence only
one instance of Tacker Conductor is deployed. one instance of each Tacker service is deployed and all on the same host.
Previous multinode deployments must manually remove all Tacker Conductors Previous multinode deployments will be descaled when running upgrade.
before proceeding with upgrade.