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:
Jesse Pretorius 2017-11-23 11:36:13 +00:00
parent 33836d3d5e
commit fe9a338b13

View File

@ -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: