Correct nova virt type detection
The nova role was attempting to detect the virt type if one was not already pre-set however the tasks would only ever set the virt type to "qemu" which forces all workloads to run in software instead of hardware virt which has massive impacts in terms of workload performance. This change corrects the virt type detection logic so that it will run fall back to qemu should another virt type not be detected. Change-Id: I78093808f03238c3c019797a06bba3ceca821239 Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
This commit is contained in:
parent
42fad6ddd7
commit
db6c7dfb73
@ -35,8 +35,6 @@
|
|||||||
|
|
||||||
- include: nova_virt_detect.yml
|
- include: nova_virt_detect.yml
|
||||||
static: no
|
static: no
|
||||||
when:
|
|
||||||
- nova_virt_type is not defined
|
|
||||||
tags:
|
tags:
|
||||||
- always
|
- always
|
||||||
- nova-config
|
- nova-config
|
||||||
|
@ -17,34 +17,32 @@
|
|||||||
command: cat /proc/cpuinfo
|
command: cat /proc/cpuinfo
|
||||||
register: cpuinfo_contents
|
register: cpuinfo_contents
|
||||||
changed_when: false
|
changed_when: false
|
||||||
tags:
|
when:
|
||||||
- always
|
- nova_virt_type is not defined
|
||||||
|
|
||||||
- name: Register a fact for the nova qemu virt type
|
|
||||||
set_fact:
|
|
||||||
nova_virt_type: "qemu"
|
|
||||||
tags:
|
|
||||||
- always
|
|
||||||
|
|
||||||
- name: Register a fact for the nova kvm virt type
|
- name: Register a fact for the nova kvm virt type
|
||||||
set_fact:
|
set_fact:
|
||||||
nova_virt_type: "kvm"
|
nova_virt_type: "kvm"
|
||||||
when:
|
when:
|
||||||
|
- nova_virt_type is not defined
|
||||||
- cpuinfo_contents.stdout.find('vmx') != -1
|
- cpuinfo_contents.stdout.find('vmx') != -1
|
||||||
or cpuinfo_contents.stdout.find('svm') != -1
|
or cpuinfo_contents.stdout.find('svm') != -1
|
||||||
or cpuinfo_contents.stdout.find('PowerNV') != -1
|
or cpuinfo_contents.stdout.find('PowerNV') != -1
|
||||||
or (cpuinfo_contents.stdout.find('pSeries') != -1
|
or (cpuinfo_contents.stdout.find('pSeries') != -1
|
||||||
and cpuinfo_contents.stdout.find('qemu') != -1
|
and cpuinfo_contents.stdout.find('qemu') != -1
|
||||||
and ansible_architecture == 'ppc64le')
|
and ansible_architecture == 'ppc64le')
|
||||||
tags:
|
|
||||||
- nova-virt-type-set
|
|
||||||
|
|
||||||
- name: Register a fact for the nova powervm virt type
|
- name: Register a fact for the nova powervm virt type
|
||||||
set_fact:
|
set_fact:
|
||||||
nova_virt_type: "powervm"
|
nova_virt_type: "powervm"
|
||||||
when:
|
when:
|
||||||
|
- nova_virt_type is not defined
|
||||||
- cpuinfo_contents.stdout.find('pSeries') != -1
|
- cpuinfo_contents.stdout.find('pSeries') != -1
|
||||||
- ansible_architecture == 'ppc64le'
|
- ansible_architecture == 'ppc64le'
|
||||||
- cpuinfo_contents.stdout.find('qemu') == -1
|
- cpuinfo_contents.stdout.find('qemu') == -1
|
||||||
tags:
|
|
||||||
- nova-virt-type-set
|
- name: Register a fact for the nova qemu virt type
|
||||||
|
set_fact:
|
||||||
|
nova_virt_type: "qemu"
|
||||||
|
when:
|
||||||
|
- nova_virt_type is not defined
|
||||||
|
Loading…
Reference in New Issue
Block a user