[Train] Fix Tacker config for the local Glance store

It turned out the previous fix ([1]) was incomplete.
Additionally, it seems we have to limit Tacker server
to one instance co-located with conductor.

[1] https://review.opendev.org/684275
commit b96ade3cf01009d822f85744efee523127f2674c

Change-Id: I9ce27d5f68f32ef59e245960e23336ae5c5db905
Closes-bug: #1853715
Related-bug: #1845142
This commit is contained in:
Radosław Piliszek 2019-11-23 21:46:11 +01:00
parent cfdcaf3ab2
commit c5f9ea9590
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.