Configure qemu group setting as hugetlbfs for ovs-dpdk

Till now, the ovs service file and ovs-ctl command files
are patched to allow ovs to run with qemu group. In order
to remove this workarounds, a new group hugetlbfs is created
which will be shared between ovs and qemu. This patch contains
the changes required for applying these changes.

Depends-On: I674cbd45e17906448dd54acfdf7a7059880b7278
Change-Id: Iec6be0b99e84b0c89f791c3c9694fe10f3a1e7db
This commit is contained in:
Saravanan KR 2017-11-29 17:44:39 +05:30
parent edd5c0c2ba
commit 785d1b2b38
3 changed files with 81 additions and 1 deletions

View File

@ -0,0 +1,15 @@
# This permission changes should be applied only on the fresh deployment of
# queens, minor updates in queens (and future) and then upgrades from queens
# to future versions.
#
# It should NOT be used for upgrade from pike, ocata, newton as the existing
# vhost ports and ovs will be with root permissions. Modifying the ovs to run
# with new user during upgrades will result in errors as the existing files and
# folders need to be updated with new permissions. If this is required during
# the upgrade, it is preferrable to do it externally after upgrade. Once the
# changes has been applied, this environment file can be used for further
# updates and upgrades.
parameter_defaults:
NeutronVhostuserSocketGroup: "hugetlbfs"

View File

@ -198,8 +198,47 @@ resources:
_TUNED_PROFILE_NAME_: {get_param: [RoleParameters, TunedProfileName]}
_TUNED_CORES_: {get_param: [RoleParameters, IsolCpusList]}
# Details @https://bugzilla.redhat.com/show_bug.cgi?id=1515269
# Ensure gid of hugetlbfs matching with kolla so that container deployment
# and baremetal (future migrating to container) deployment have same id. This
# is a new group created from ovs2.8 onwards. 42477 is the kolla hugetlbfs
# gid value. Ensure that it is applied and restart(ovs) or reboot(host)
# before starting with DPDK initialization.
DpdkVhostGroupConfig:
type: OS::Heat::SoftwareConfig
depends_on: HostParametersDeployment
condition: is_dpdk_config_required
properties:
group: ansible
outputs:
- name: result
config: |
---
- hosts: localhost
connection: local
gather_facts: False
tasks:
- group:
name: "hugetlbfs"
gid: 42477
DpdkVhostGroupDeployment:
type: OS::Heat::SoftwareDeployment
depends_on: HostParametersDeployment
condition: is_dpdk_config_required
properties:
name: DpdkVhostGroupDeployment
server: {get_param: server}
config: {get_resource: DpdkVhostGroupConfig}
actions:
if:
- deployment_actions_empty
- []
- ['CREATE'] # Only do this on CREATE
RebootConfig:
type: OS::Heat::SoftwareConfig
depends_on: DpdkVhostGroupDeployment
condition: is_reboot_config_required
properties:
group: script
@ -212,7 +251,7 @@ resources:
RebootDeployment:
type: OS::Heat::SoftwareDeployment
depends_on: HostParametersDeployment
depends_on: DpdkVhostGroupDeployment
condition: is_reboot_config_required
properties:
name: RebootDeployment
@ -234,6 +273,7 @@ resources:
# maintained, restart of ovs is required.
EnableDpdkConfig:
type: OS::Heat::SoftwareConfig
depends_on: RebootDeployment
condition: is_dpdk_config_required
properties:
group: script

View File

@ -45,6 +45,24 @@ parameters:
type: string
tags:
- role_specific
NeutronVhostuserSocketGroup:
default: "qemu"
description: >
The vhost-user socket directory group name.
Defaults to 'qemu'. When vhostuser mode is 'dpdkvhostuserclient'
(which is the default mode), the vhost socket is created by qemu.
type: string
tags:
- role_specific
NeutronVhostuserSocketUser:
default: "qemu"
description: >
The vhost-user socket directory user name.
Defaults to 'qemu'. When vhostuser mode is 'dpdkvhostuserclient'
(which is the default mode), the vhost socket is created by qemu.
type: string
tags:
- role_specific
resources:
@ -69,10 +87,14 @@ resources:
- map_replace:
- neutron::agents::ml2::ovs::datapath_type: NeutronDatapathType
neutron::agents::ml2::ovs::vhostuser_socket_dir: NeutronVhostuserSocketDir
vhostuser_socket_group: NeutronVhostuserSocketGroup
vhostuser_socket_user: NeutronVhostuserSocketUser
- values: {get_param: [RoleParameters]}
- values:
NeutronDatapathType: {get_param: NeutronDatapathType}
NeutronVhostuserSocketDir: {get_param: NeutronVhostuserSocketDir}
NeutronVhostuserSocketGroup: {get_param: NeutronVhostuserSocketGroup}
NeutronVhostuserSocketUser: {get_param: NeutronVhostuserSocketUser}
Ovs:
type: ./openvswitch.yaml
@ -97,6 +119,9 @@ outputs:
- neutron::agents::ml2::ovs::enable_dpdk: true
- get_attr: [Ovs, role_data, config_settings]
- get_attr: [RoleParametersValue, value]
service_config_settings:
nova_libvirt:
nova::compute::libvirt::qemu::group: {get_attr: [RoleParametersValue, value, vhostuser_socket_group]}
step_config: {get_attr: [NeutronOvsAgent, role_data, step_config]}
upgrade_tasks:
get_attr: [Ovs, role_data, upgrade_tasks]