Do not implement reload for novnc/spice service
The nova-novncproxy and nova-spicehtml5proxy services do not support using a HUP signal to reload, so they need to be restarted instead. This patch ensures that these services are restarted, and also fixes a bug that hasn't been noticed before where if the Placement API and other nova services are implemented on the same host/container then the other services would not be restarted. It would play out like this: - The first task asks to reload all nova services execute against all nova hosts, except those running the placement api. This results in only the compute hosts getting the reload. - The second task only asks the nova placement API to restart. This leaves out all the other nova services which are on the same host. Change-Id: Id4b9caa1cdfd0f53023548c4ede5d497d64c873d Needed-By: I36e2200e2ca43d87208d2c4edb17b98654bb121e
This commit is contained in:
parent
33836d3d5e
commit
fe9a338b13
@ -173,11 +173,11 @@
|
|||||||
run_once: yes
|
run_once: yes
|
||||||
|
|
||||||
|
|
||||||
# Note that the placement API service does not understand how to reload,
|
# Note that the placement API service and the console services do not
|
||||||
# so it fails when you try to make it do so. We therefore skip the reload
|
# understand how to reload, so they fail when you try to make them do
|
||||||
# for that service.
|
# so. We therefore restart them instead.
|
||||||
- name: Reload all nova services to ensure new RPC object version is used
|
- name: Reload all nova services which support a reload to ensure new RPC object version is used
|
||||||
hosts: "nova_all:!nova_api_placement"
|
hosts: "nova_all:!nova_api_placement:!nova_console"
|
||||||
gather_facts: no
|
gather_facts: no
|
||||||
serial: "{{ nova_serial | default('100%') }}"
|
serial: "{{ nova_serial | default('100%') }}"
|
||||||
max_fail_percentage: 20
|
max_fail_percentage: 20
|
||||||
@ -191,17 +191,18 @@
|
|||||||
vars:
|
vars:
|
||||||
service_name: "nova"
|
service_name: "nova"
|
||||||
service_action: "reloaded"
|
service_action: "reloaded"
|
||||||
service_negate: "{{ ['nova-placement-api.service'] + nova_service_negate | default([]) }}"
|
service_negate: "{{ ['nova-placement-api.service', 'nova-novncproxy.service', 'nova-spicehtml5proxy.service' ] + nova_service_negate | default([]) }}"
|
||||||
when:
|
when:
|
||||||
- "nova_all_software_updated | bool"
|
- "nova_all_software_updated | bool"
|
||||||
- "ansible_local['openstack_ansible']['nova']['need_service_restart'] | bool"
|
- "ansible_local['openstack_ansible']['nova']['need_service_restart'] | bool"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Note that the placement API service does not understand how to reload,
|
# Note that the placement API service and the console services do not
|
||||||
# so it fails when you try to make it do so. We therefore restart it instead.
|
# understand how to reload, so they fail when you try to make them do
|
||||||
- name: Restart the nova placement API service to ensure new RPC object version is used
|
# so. We therefore restart them instead.
|
||||||
hosts: "nova_api_placement"
|
- name: Restart the remaining nova services to ensure new RPC object version is used
|
||||||
|
hosts: "nova_api_placement:nova_console"
|
||||||
gather_facts: no
|
gather_facts: no
|
||||||
serial: "{{ nova_api_serial | default(['1', '100%']) }}"
|
serial: "{{ nova_api_serial | default(['1', '100%']) }}"
|
||||||
max_fail_percentage: 20
|
max_fail_percentage: 20
|
||||||
@ -213,7 +214,7 @@
|
|||||||
- name: Execute nova service restart
|
- name: Execute nova service restart
|
||||||
include: common-tasks/restart-service.yml
|
include: common-tasks/restart-service.yml
|
||||||
vars:
|
vars:
|
||||||
service_name: "nova-placement-api"
|
service_name: "nova"
|
||||||
service_action: "restarted"
|
service_action: "restarted"
|
||||||
service_fact: "nova"
|
service_fact: "nova"
|
||||||
when:
|
when:
|
||||||
|
Loading…
Reference in New Issue
Block a user