Aligning OVS and Neutron configuration for DPDK

This change aligns DPDK configuration parameters across the OVS and Neutron
charts.

Change-Id: I381286a49dfe65762cfb4a344e7bd178e42f10f6
This commit is contained in:
Georg Kunz 2019-08-13 13:07:01 +02:00 committed by Deepak
parent 49c8c744ac
commit c0dda7785f
6 changed files with 68 additions and 23 deletions

View File

@ -24,8 +24,10 @@ OVS_PID=/run/openvswitch/ovs-vswitchd.pid
# Create vhostuser directory and grant nova user (default UID 42424) access # Create vhostuser directory and grant nova user (default UID 42424) access
# permissions. # permissions.
mkdir -p /run/openvswitch/vhostuser {{- if .Values.conf.ovs_dpdk.enabled }}
chown {{ .Values.pod.user.nova.uid }}.{{ .Values.pod.user.nova.uid }} /run/openvswitch/vhostuser mkdir -p /run/openvswitch/{{ .Values.conf.ovs_dpdk.vhostuser_socket_dir }}
chown {{ .Values.pod.user.nova.uid }}.{{ .Values.pod.user.nova.uid }} /run/openvswitch/{{ .Values.conf.ovs_dpdk.vhostuser_socket_dir }}
{{- end }}
function start () { function start () {
t=0 t=0
@ -41,23 +43,23 @@ function start () {
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait show ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait show
{{- if .Values.conf.dpdk.enabled }} {{- if .Values.conf.ovs_dpdk.enabled }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-hugepage-dir={{ .Values.conf.dpdk.hugepages_mountpath | quote }} ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-hugepage-dir={{ .Values.conf.ovs_dpdk.hugepages_mountpath | quote }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-socket-mem={{ .Values.conf.dpdk.socket_memory | quote }} ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-socket-mem={{ .Values.conf.ovs_dpdk.socket_memory | quote }}
{{- if .Values.conf.dpdk.mem_channels }} {{- if .Values.conf.ovs_dpdk.mem_channels }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-mem-channels={{ .Values.conf.dpdk.mem_channels | quote }} ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-mem-channels={{ .Values.conf.ovs_dpdk.mem_channels | quote }}
{{- end }} {{- end }}
{{- if .Values.conf.dpdk.pmd_cpu_mask }} {{- if .Values.conf.ovs_dpdk.pmd_cpu_mask }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:pmd-cpu-mask={{ .Values.conf.dpdk.pmd_cpu_mask | quote }} ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:pmd-cpu-mask={{ .Values.conf.ovs_dpdk.pmd_cpu_mask | quote }}
{{- end }} {{- end }}
{{- if .Values.conf.dpdk.lcore_mask }} {{- if .Values.conf.ovs_dpdk.lcore_mask }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-lcore-mask={{ .Values.conf.dpdk.lcore_mask | quote }} ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-lcore-mask={{ .Values.conf.ovs_dpdk.lcore_mask | quote }}
{{- end }} {{- end }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:vhost-sock-dir="vhostuser" ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:vhost-sock-dir={{ .Values.conf.ovs_dpdk.vhostuser_socket_dir | quote }}
ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-init=true ovs-vsctl --db=unix:${OVS_SOCKET} --no-wait set Open_vSwitch . other_config:dpdk-init=true
{{- end }} {{- end }}

View File

@ -82,14 +82,14 @@ spec:
readOnly: true readOnly: true
containers: containers:
- name: openvswitch-vswitchd - name: openvswitch-vswitchd
{{- if .Values.conf.dpdk.enabled }} {{- if .Values.conf.ovs_dpdk.enabled }}
{{/* Run the container in priviledged mode due to the need for root {{/* Run the container in priviledged mode due to the need for root
permissions when using the uio_pci_generic driver. */}} permissions when using the uio_pci_generic driver. */}}
{{- $_ := set $envAll.Values.pod.security_context.openvswitch_vswitchd.container.vswitchd "privileged" true -}} {{- $_ := set $envAll.Values.pod.security_context.openvswitch_vswitchd.container.vswitchd "privileged" true -}}
{{- end }} {{- end }}
{{ tuple $envAll "openvswitch_vswitchd" | include "helm-toolkit.snippets.image" | indent 10 }} {{ tuple $envAll "openvswitch_vswitchd" | include "helm-toolkit.snippets.image" | indent 10 }}
{{ dict "envAll" $envAll "application" "openvswitch_vswitchd" "container" "vswitchd" | include "helm-toolkit.snippets.kubernetes_container_security_context" | indent 10 }} {{ dict "envAll" $envAll "application" "openvswitch_vswitchd" "container" "vswitchd" | include "helm-toolkit.snippets.kubernetes_container_security_context" | indent 10 }}
{{- if .Values.conf.dpdk.enabled }} {{- if .Values.conf.ovs_dpdk.enabled }}
{{/* When running with DPDK, we need to specify the type and amount of hugepages. {{/* When running with DPDK, we need to specify the type and amount of hugepages.
The following line enables resource handling in general, but the type and amount The following line enables resource handling in general, but the type and amount
of hugepages must still be defined in the values.yaml.*/}} of hugepages must still be defined in the values.yaml.*/}}
@ -118,9 +118,9 @@ of hugepages must still be defined in the values.yaml.*/}}
readOnly: true readOnly: true
- name: run - name: run
mountPath: /run mountPath: /run
{{- if .Values.conf.dpdk.enabled }} {{- if .Values.conf.ovs_dpdk.enabled }}
- name: hugepages - name: hugepages
mountPath: {{ .Values.conf.dpdk.hugepages_mountpath | quote }} mountPath: {{ .Values.conf.ovs_dpdk.hugepages_mountpath | quote }}
- name: pci-devices - name: pci-devices
mountPath: /sys/bus/pci/devices mountPath: /sys/bus/pci/devices
- name: huge-pages-kernel - name: huge-pages-kernel
@ -149,7 +149,7 @@ of hugepages must still be defined in the values.yaml.*/}}
hostPath: hostPath:
path: / path: /
type: Directory type: Directory
{{- if .Values.conf.dpdk.enabled }} {{- if .Values.conf.ovs_dpdk.enabled }}
- name: devs - name: devs
hostPath: hostPath:
path: /dev path: /dev
@ -176,7 +176,7 @@ of hugepages must still be defined in the values.yaml.*/}}
type: Directory type: Directory
- name: hugepages - name: hugepages
hostPath: hostPath:
path: {{ .Values.conf.dpdk.hugepages_mountpath | quote }} path: {{ .Values.conf.ovs_dpdk.hugepages_mountpath | quote }}
type: Directory type: Directory
{{- end }} {{- end }}
{{- end }} {{- end }}

View File

@ -188,12 +188,13 @@ manifests:
conf: conf:
openvswitch_db_server: openvswitch_db_server:
ptcp_port: null ptcp_port: null
dpdk: ovs_dpdk:
enabled: false enabled: false
socket_memory: 1024 ## Mandatory parameters. Please uncomment when enabling DPDK
hugepages_mountpath: /dev/hugepages # socket_memory: 1024
# optional parameters for tuning the OVS config # hugepages_mountpath: /dev/hugepages
# in alignment with the available hardware resources # vhostuser_socket_dir: vhostuser
## Optional hardware specific parameters: modify to match NUMA topology
# mem_channels: 4 # mem_channels: 4
# lcore_mask: 0x1 # lcore_mask: 0x1
# pmd_cpu_mask: 0x4 # pmd_cpu_mask: 0x4

View File

@ -3,3 +3,21 @@ images:
tags: tags:
openvswitch_db_server: docker.io/openstackhelm/openvswitch:latest-opensuse_15-dpdk openvswitch_db_server: docker.io/openstackhelm/openvswitch:latest-opensuse_15-dpdk
openvswitch_vswitchd: docker.io/openstackhelm/openvswitch:latest-opensuse_15-dpdk openvswitch_vswitchd: docker.io/openstackhelm/openvswitch:latest-opensuse_15-dpdk
pod:
resources:
enabled: true
ovs:
vswitchd:
requests:
memory: "2Gi"
cpu: "2"
limits:
memory: "2Gi"
cpu: "2"
hugepages-1Gi: "1Gi"
conf:
ovs_dpdk:
enabled: true
hugepages_mountpath: /dev/hugepages
vhostuser_socket_dir: vhostuser
socket_memory: 1024

View File

@ -3,3 +3,21 @@ images:
tags: tags:
openvswitch_db_server: docker.io/openstackhelm/openvswitch:latest-ubuntu_bionic-dpdk openvswitch_db_server: docker.io/openstackhelm/openvswitch:latest-ubuntu_bionic-dpdk
openvswitch_vswitchd: docker.io/openstackhelm/openvswitch:latest-ubuntu_bionic-dpdk openvswitch_vswitchd: docker.io/openstackhelm/openvswitch:latest-ubuntu_bionic-dpdk
pod:
resources:
enabled: true
ovs:
vswitchd:
requests:
memory: "2Gi"
cpu: "2"
limits:
memory: "2Gi"
cpu: "2"
hugepages-1Gi: "1Gi"
conf:
ovs_dpdk:
enabled: true
hugepages_mountpath: /dev/hugepages
vhostuser_socket_dir: vhostuser
socket_memory: 1024

View File

@ -0,0 +1,6 @@
---
other:
- |
The root configuration key of the DPDK section has been changed from
"dpdk" to "ovs_dpdk" to achieve parity with the corresponding configuration
key in the Neutron chart.