9fe70f45f3
As neutron-vpnaas-agent has been loaded just inside of the existing l3 agent rather than requiring operators to run a completely different binary with a subclass of the existing L3 agent[1]. We need restructure this role to fit with this new feature. [1] https://review.openstack.org/488247 Depends-On: I47cd8ba5a14da3c76d5b1eb0b4c0cf0c729eb2ff Change-Id: Id690a652bc9facf1c3e39358f548ab7ddd967d80 Implements: blueprint restructure-neutron-vpnaas Closes-Bug: #1731498
84 lines
3.8 KiB
YAML
84 lines
3.8 KiB
YAML
---
|
|
####################
|
|
# Services
|
|
####################
|
|
|
|
ovsdpdk_services:
|
|
ovsdpdk-db:
|
|
container_name: "ovsdpdk_db"
|
|
image: "{{ ovsdpdk_db_image_full }}"
|
|
enabled: "{{ neutron_plugin_agent in ['openvswitch', 'opendaylight'] }}"
|
|
host_in_groups: >-
|
|
{{
|
|
inventory_hostname in groups['compute']
|
|
or (enable_manila | bool and inventory_hostname in groups['manila-share'])
|
|
or inventory_hostname in groups['neutron-dhcp-agent']
|
|
or inventory_hostname in groups['neutron-l3-agent']
|
|
or inventory_hostname in groups['neutron-metadata-agent']
|
|
}}
|
|
volumes:
|
|
- "{{ node_config_directory }}/ovsdpdk-db/:{{ container_config_directory }}/:ro"
|
|
- "/etc/localtime:/etc/localtime:ro"
|
|
- "/run:/run:shared"
|
|
- "kolla_logs:/var/log/kolla/"
|
|
- "ovsdpdk_db:/var/lib/openvswitch/"
|
|
ovsdpdk-vswitchd:
|
|
container_name: "ovsdpdk_vswitchd"
|
|
image: "{{ ovsdpdk_vswitchd_image_full }}"
|
|
enabled: "{{ neutron_plugin_agent in ['openvswitch', 'opendaylight'] }}"
|
|
privileged: True
|
|
host_in_groups: >-
|
|
{{
|
|
inventory_hostname in groups['compute']
|
|
or (enable_manila | bool and inventory_hostname in groups['manila-share'])
|
|
or inventory_hostname in groups['neutron-dhcp-agent']
|
|
or inventory_hostname in groups['neutron-l3-agent']
|
|
or inventory_hostname in groups['neutron-metadata-agent']
|
|
}}
|
|
volumes:
|
|
- "{{ node_config_directory }}/ovsdpdk-vswitchd/:{{ container_config_directory }}/:ro"
|
|
- "/etc/localtime:/etc/localtime:ro"
|
|
- "/lib/modules:/lib/modules:ro"
|
|
- "/run:/run:shared"
|
|
- "/dev:/dev:shared"
|
|
- "kolla_logs:/var/log/kolla/"
|
|
|
|
####################
|
|
# OVS
|
|
####################
|
|
ovs_bridge_mappings: "{% for bridge in neutron_bridge_name.split(',') %}physnet{{ loop.index0 + 1 }}:{{ bridge }}{% if not loop.last %},{% endif %}{% endfor %}"
|
|
ovs_port_mappings: "{% for bridge in neutron_bridge_name.split(',') %} {{ neutron_external_interface.split(',')[loop.index0] }}:{{ bridge }}{% if not loop.last %},{% endif %}{% endfor %}"
|
|
dpdk_tunnel_interface: "{{neutron_external_interface}}"
|
|
dpdk_tunnel_interface_address: "{{ hostvars[inventory_hostname]['ansible_' + dpdk_tunnel_interface]['ipv4']['address'] }}"
|
|
tunnel_interface_network: "{{ hostvars[inventory_hostname]['ansible_' + dpdk_tunnel_interface]['ipv4']['network']}}/{{hostvars[inventory_hostname]['ansible_' + dpdk_tunnel_interface]['ipv4']['netmask']}}"
|
|
tunnel_interface_cidr: "{{dpdk_tunnel_interface_address}}/{{ tunnel_interface_network | ipaddr('prefix') }}"
|
|
ovs_cidr_mappings: "{% if neutron_bridge_name.split(',')|length != 1 %} {neutron_bridge_name.split(',')[0]}:{{ tunnel_interface_cidr }} {% else %} {{ neutron_bridge_name }}:{{ tunnel_interface_cidr }} {% endif %}"
|
|
ovs_mem_channels: 4
|
|
ovs_socket_mem: 1024
|
|
ovs_hugepage_mountpoint: /dev/hugepages
|
|
|
|
# ovs <2.7 required dpdk phyical port names to be index
|
|
# in pci address order as dpdkX where X is the index
|
|
# ovs>=2.7 allows arbitray names but the pci address
|
|
# must be set in a new dpdkdev-opt field
|
|
# valid values are indexed or named.
|
|
ovs_physical_port_policy: named
|
|
|
|
project_name: "ovs"
|
|
neutron_bridge_name: "br_dpdk"
|
|
|
|
|
|
####################
|
|
# Docker
|
|
####################
|
|
ovsdpdk_install_type: "{{ kolla_install_type }}"
|
|
ovsdpdk_tag: "{{ openstack_release }}"
|
|
|
|
ovsdpdk_db_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ ovsdpdk_install_type }}-ovsdpdk-db"
|
|
ovsdpdk_db_tag: "{{ ovsdpdk_tag }}"
|
|
ovsdpdk_db_image_full: "{{ ovsdpdk_db_image }}:{{ ovsdpdk_db_tag }}"
|
|
|
|
ovsdpdk_vswitchd_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ ovsdpdk_install_type }}-ovsdpdk-vswitchd"
|
|
ovsdpdk_vswitchd_tag: "{{ ovsdpdk_tag }}"
|
|
ovsdpdk_vswitchd_image_full: "{{ ovsdpdk_vswitchd_image }}:{{ ovsdpdk_vswitchd_tag }}"
|