Merge "Aligning OVS and Neutron configuration for DPDK"
This commit is contained in:
commit
1478962d18
@ -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 }}
|
||||||
|
|
||||||
|
@ -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 }}
|
||||||
|
@ -190,12 +190,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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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.
|
Loading…
Reference in New Issue
Block a user