Dmitriy Rabotyagov 4e855db6b2 Add VPNaaS OVN support
At the moment it's possible to deploy VPNaaS for non-OVN environemnts only.
OVN implementation is slighly different and requires a standalone agent to
run on gateway hosts, where OVN router is active.

This agent spawns namespaces as used to do and talks through RPC with API.

More detailed spec on the feature can be found here [1]. There's also
configuration reference in progress of writing [2].

[1] https://opendev.org/openstack/neutron-specs/src/branch/master/specs/xena/vpnaas-ovn.rst
[2] https://review.opendev.org/c/openstack/neutron-vpnaas/+/895651
Change-Id: Idb223ee0d8187f372682aafda1b8d6fd78cb71d1

Change-Id: Iad163ac7b032a97bd49164d94490b0f0deb83d90
2024-02-20 12:37:13 +00:00

123 lines
2.9 KiB
YAML

---
# Copyright 2016, Rackspace US, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
neutron_repos:
- centos-release-nfv-openvswitch
neutron_ovs_distro_packages:
- openvswitch
dpdk_service_name: openvswitch
vhost_socket_directory_group: hugetlbfs
vhost_socket_directory_owner: qemu
neutron_ovs_service_name: openvswitch
neutron_ovn_northd_service_name: ovn-northd
neutron_ovn_controller_service_name: ovn-controller
neutron_ovn_northd_opts: "OVN_NORTHD_OPTS"
neutron_ovn_northd_opts_file: "/etc/sysconfig/ovn-northd"
neutron_ovn_controller_opts: "OVN_CONTROLLER_OPTS"
neutron_ovn_controller_opts_file: "/etc/sysconfig/ovn-controller"
neutron_ovn_system_user_name: openvswitch
neutron_distro_packages:
- conntrack-tools
- dnsmasq
- dnsmasq-utils
- ebtables
- libxml2
- ipset
- iptables
- iputils
- keepalived
- net-tools
- radvd
- which
neutron_ovn_distro_packages:
- openvswitch-ovn-common
neutron_ovn_controller_distro_packages:
- openvswitch-ovn-host
- haproxy
neutron_ovn_northd_distro_packages:
- openvswitch-ovn-central
neutron_devel_distro_packages:
- git
- systemd-devel
neutron_service_distro_packages:
- openstack-neutron
- openstack-neutron-ml2
- openstack-neutron-macvtap-agent
- openstack-neutron-metering-agent
- openstack-neutron-l2gw-agent
- python3-memcached
- python3-systemd
neutron_optional_ovs_distro_packages:
- openstack-neutron-openvswitch
neutron_optional_lxb_distro_packages:
- openstack-neutron-linuxbridge
neutron_optional_fwaas_distro_packages:
- openstack-neutron-fwaas
neutron_optional_vpnaas_distro_packages:
- openstack-neutron-vpnaas
neutron_lxb_distro_packages:
- bridge-utils
neutron_vpnaas_distro_packages:
- libreswan
_neutron_driver_vpnaas: >-
{{
(neutron_plugin_type == 'ml2.ovn') | ternary(
'neutron_vpnaas.services.vpn.device_drivers.ovn_ipsec.OvnLibreSwanDriver',
'neutron_vpnaas.services.vpn.device_drivers.libreswan_ipsec.LibreSwanDriver'
)
}}
_neutron_vpnaas_service_provider: >-
{{
(neutron_plugin_type == 'ml2.ovn') | ternary(
'VPN:openswan:neutron_vpnaas.services.vpn.service_drivers.ovn_ipsec.IPsecOvnVPNDriver:default',
'VPN:openswan:neutron_vpnaas.services.vpn.service_drivers.ipsec.IPsecVPNDriver:default'
)
}}
neutron_metadata_agent_distro_packages:
- haproxy
neutron_remove_distro_packages: []
neutron_oslomsg_amqp1_distro_packages:
- cyrus-sasl-lib
- cyrus-sasl-plain
- cyrus-sasl-md5