Merge "neutron: Add neutron-ovn-agent support"

This commit is contained in:
Zuul
2023-05-19 13:42:55 +00:00
committed by Gerrit Code Review
12 changed files with 144 additions and 0 deletions

View File

@@ -1018,6 +1018,9 @@ neutron_enable_tls_backend: "{{ kolla_enable_tls_backend }}"
# Set OVN network availability zones # Set OVN network availability zones
neutron_ovn_availability_zones: [] neutron_ovn_availability_zones: []
# Enable OVN agent
neutron_enable_ovn_agent: "no"
####################### #######################
# Nova options # Nova options
####################### #######################

View File

@@ -283,6 +283,9 @@ neutron
compute compute
network network
[neutron-ovn-agent:children]
compute
[neutron-bgp-dragent:children] [neutron-bgp-dragent:children]
neutron neutron

View File

@@ -313,6 +313,10 @@ neutron
[ironic-neutron-agent:children] [ironic-neutron-agent:children]
neutron neutron
[neutron-ovn-agent:children]
compute
network
# Cinder # Cinder
[cinder-api:children] [cinder-api:children]
cinder cinder

View File

@@ -197,6 +197,15 @@ neutron_services:
port: "{{ neutron_server_port }}" port: "{{ neutron_server_port }}"
listen_port: "{{ neutron_server_listen_port }}" listen_port: "{{ neutron_server_listen_port }}"
tls_backend: "yes" tls_backend: "yes"
neutron-ovn-agent:
container_name: neutron_ovn_agent
group: neutron-ovn-agent
host_in_groups: "{{ inventory_hostname in groups['neutron-ovn-agent'] }}"
enabled: "{{ neutron_enable_ovn_agent | bool }}"
image: "{{ neutron_ovn_agent_image_full }}"
volumes: "{{ neutron_ovn_agent_default_volumes + neutron_ovn_agent_extra_volumes }}"
dimensions: "{{ neutron_ovn_agent_dimensions }}"
healthcheck: "{{ neutron_ovn_agent_healthcheck }}"
#################### ####################
# Config Validate # Config Validate
@@ -312,6 +321,10 @@ neutron_tls_proxy_image: "{{ docker_registry ~ '/' if docker_registry else '' }}
neutron_tls_proxy_tag: "{{ haproxy_tag }}" neutron_tls_proxy_tag: "{{ haproxy_tag }}"
neutron_tls_proxy_image_full: "{{ neutron_tls_proxy_image }}:{{ neutron_tls_proxy_tag }}" neutron_tls_proxy_image_full: "{{ neutron_tls_proxy_image }}:{{ neutron_tls_proxy_tag }}"
neutron_ovn_agent_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/neutron-ovn-agent"
neutron_ovn_agent_tag: "{{ neutron_tag }}"
neutron_ovn_agent_image_full: "{{ neutron_ovn_agent_image }}:{{ neutron_ovn_agent_tag }}"
neutron_agent_dimensions: "{{ default_container_dimensions }}" neutron_agent_dimensions: "{{ default_container_dimensions }}"
neutron_dhcp_agent_dimensions: "{{ neutron_agent_dimensions }}" neutron_dhcp_agent_dimensions: "{{ neutron_agent_dimensions }}"
@@ -329,6 +342,7 @@ neutron_infoblox_ipam_agent_dimensions: "{{ default_container_dimensions }}"
neutron_metering_agent_dimensions: "{{ neutron_agent_dimensions }}" neutron_metering_agent_dimensions: "{{ neutron_agent_dimensions }}"
ironic_neutron_agent_dimensions: "{{ default_container_dimensions }}" ironic_neutron_agent_dimensions: "{{ default_container_dimensions }}"
neutron_tls_proxy_dimensions: "{{ default_container_dimensions }}" neutron_tls_proxy_dimensions: "{{ default_container_dimensions }}"
neutron_ovn_agent_dimensions: "{{ neutron_agent_dimensions }}"
neutron_dhcp_agent_enable_healthchecks: "{{ enable_container_healthchecks }}" neutron_dhcp_agent_enable_healthchecks: "{{ enable_container_healthchecks }}"
neutron_dhcp_agent_healthcheck_interval: "{{ default_container_healthcheck_interval }}" neutron_dhcp_agent_healthcheck_interval: "{{ default_container_healthcheck_interval }}"
@@ -460,6 +474,19 @@ neutron_sriov_agent_healthcheck:
test: "{% if neutron_sriov_agent_enable_healthchecks | bool %}{{ neutron_sriov_agent_healthcheck_test }}{% else %}NONE{% endif %}" test: "{% if neutron_sriov_agent_enable_healthchecks | bool %}{{ neutron_sriov_agent_healthcheck_test }}{% else %}NONE{% endif %}"
timeout: "{{ neutron_sriov_agent_healthcheck_timeout }}" timeout: "{{ neutron_sriov_agent_healthcheck_timeout }}"
neutron_ovn_agent_enable_healthchecks: "{{ enable_container_healthchecks }}"
neutron_ovn_agent_healthcheck_interval: "{{ default_container_healthcheck_interval }}"
neutron_ovn_agent_healthcheck_retries: "{{ default_container_healthcheck_retries }}"
neutron_ovn_agent_healthcheck_start_period: "{{ default_container_healthcheck_start_period }}"
neutron_ovn_agent_healthcheck_test: ["CMD-SHELL", "healthcheck_port python {{ ovn_sb_db_port }}"]
neutron_ovn_agent_healthcheck_timeout: "{{ default_container_healthcheck_timeout }}"
neutron_ovn_agent_healthcheck:
interval: "{{ neutron_ovn_agent_healthcheck_interval }}"
retries: "{{ neutron_ovn_agent_healthcheck_retries }}"
start_period: "{{ neutron_ovn_agent_healthcheck_start_period }}"
test: "{% if neutron_ovn_agent_enable_healthchecks | bool %}{{ neutron_ovn_agent_healthcheck_test }}{% else %}NONE{% endif %}"
timeout: "{{ neutron_ovn_agent_healthcheck_timeout }}"
ironic_neutron_agent_enable_healthchecks: "{{ enable_container_healthchecks }}" ironic_neutron_agent_enable_healthchecks: "{{ enable_container_healthchecks }}"
ironic_neutron_agent_healthcheck_interval: "{{ default_container_healthcheck_interval }}" ironic_neutron_agent_healthcheck_interval: "{{ default_container_healthcheck_interval }}"
ironic_neutron_agent_healthcheck_retries: "{{ default_container_healthcheck_retries }}" ironic_neutron_agent_healthcheck_retries: "{{ default_container_healthcheck_retries }}"
@@ -571,6 +598,11 @@ neutron_tls_proxy_default_volumes:
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}" - "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
neutron_ovn_agent_default_volumes:
- "{{ node_config_directory }}/neutron-ovn-agent/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}"
- "kolla_logs:/var/log/kolla/"
neutron_extra_volumes: "{{ default_extra_volumes }}" neutron_extra_volumes: "{{ default_extra_volumes }}"
neutron_dhcp_agent_extra_volumes: "{{ neutron_extra_volumes }}" neutron_dhcp_agent_extra_volumes: "{{ neutron_extra_volumes }}"
@@ -588,6 +620,7 @@ neutron_infoblox_ipam_agent_extra_volumes: "{{ neutron_extra_volumes }}"
neutron_metering_agent_extra_volumes: "{{ neutron_extra_volumes }}" neutron_metering_agent_extra_volumes: "{{ neutron_extra_volumes }}"
ironic_neutron_agent_extra_volumes: "{{ neutron_extra_volumes }}" ironic_neutron_agent_extra_volumes: "{{ neutron_extra_volumes }}"
neutron_tls_proxy_extra_volumes: "{{ neutron_extra_volumes }}" neutron_tls_proxy_extra_volumes: "{{ neutron_extra_volumes }}"
neutron_ovn_agent_extra_volumes: "{{ neutron_extra_volumes }}"
#################### ####################
# OpenStack # OpenStack

View File

@@ -322,3 +322,20 @@
healthcheck: "{{ service.healthcheck | default(omit) }}" healthcheck: "{{ service.healthcheck | default(omit) }}"
when: when:
- kolla_action != "config" - kolla_action != "config"
- name: Restart neutron-ovn-agent container
vars:
service_name: "neutron-ovn-agent"
service: "{{ neutron_services[service_name] }}"
become: true
kolla_docker:
action: "recreate_or_restart_container"
common_options: "{{ docker_common_options }}"
name: "{{ service.container_name }}"
image: "{{ service.image }}"
volumes: "{{ service.volumes }}"
dimensions: "{{ service.dimensions }}"
privileged: "{{ service.privileged | default(False) }}"
healthcheck: "{{ service.healthcheck | default(omit) }}"
when:
- kolla_action != "config"

View File

@@ -103,6 +103,7 @@
- "neutron-sriov-agent" - "neutron-sriov-agent"
- "neutron-mlnx-agent" - "neutron-mlnx-agent"
- "neutron-eswitchd" - "neutron-eswitchd"
- "neutron-ovn-agent"
merge_configs: merge_configs:
sources: sources:
- "{{ role_path }}/templates/neutron.conf.j2" - "{{ role_path }}/templates/neutron.conf.j2"
@@ -407,6 +408,23 @@
notify: notify:
- "Restart {{ service_name }} container" - "Restart {{ service_name }} container"
- name: Copying over ovn_agent.ini
become: true
vars:
service_name: "neutron-ovn-agent"
neutron_ovn_agent: "{{ neutron_services[service_name] }}"
merge_configs:
sources:
- "{{ role_path }}/templates/ovn_agent.ini.j2"
- "{{ node_custom_config }}/neutron/ovn_agent.ini"
dest: "{{ node_config_directory }}/{{ service_name }}/ovn_agent.ini"
mode: "0660"
when:
- neutron_ovn_agent.enabled | bool
- neutron_ovn_agent.host_in_groups | bool
notify:
- "Restart {{ service_name }} container"
- name: Copying over nsx.ini - name: Copying over nsx.ini
become: true become: true
vars: vars:

View File

@@ -0,0 +1,35 @@
{
"command": "neutron-ovn-agent --config-file /etc/neutron/neutron.conf --config-file /etc/neutron/plugins/ml2/ovn_agent.ini",
"config_files": [
{
"source": "{{ container_config_directory }}/neutron.conf",
"dest": "/etc/neutron/neutron.conf",
"owner": "neutron",
"perm": "0600"
},
{
"source": "{{ container_config_directory }}/ovn_agent.ini",
"dest": "/etc/neutron/plugins/ml2/ovn_agent.ini",
"owner": "neutron",
"perm": "0600"
}
{% if neutron_policy_file is defined %},{
"source": "{{ container_config_directory }}/{{ neutron_policy_file }}",
"dest": "/etc/neutron/{{ neutron_policy_file }}",
"owner": "neutron",
"perm": "0600"
}{% endif %}
],
"permissions": [
{
"path": "/var/log/kolla/neutron",
"owner": "neutron:neutron",
"recurse": true
},
{
"path": "/var/lib/neutron/kolla",
"owner": "neutron:neutron",
"recurse": true
}
]
}

View File

@@ -0,0 +1,7 @@
[ovn]
ovn_nb_connection = {{ ovn_nb_connection }}
ovn_sb_connection = {{ ovn_sb_connection }}
[ovs]
ovsdb_connection = tcp:127.0.0.1:{{ ovsdb_port }}
ovsdb_timeout = {{ ovsdb_timeout }}

View File

@@ -171,6 +171,15 @@ This might be desired for example when Ironic bare metal nodes are
used as a compute service. Currently OVN is not able to answer DHCP used as a compute service. Currently OVN is not able to answer DHCP
queries on port type external, this is where Neutron agent helps. queries on port type external, this is where Neutron agent helps.
In order to deploy Neutron OVN Agent you need to set the following:
.. path /etc/kolla/globals.yml
.. code-block:: yaml
neutron_enable_ovn_agent: "yes"
Currently the agent is only needed for QoS for hardware offloaded ports.
Mellanox Infiniband (ml2/mlnx) Mellanox Infiniband (ml2/mlnx)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

View File

@@ -0,0 +1,10 @@
---
features:
- |
Adds support for deploying ``neutron-ovn-agent``. The agent is disabled
by default and can be enabled using ``neutron_enable_ovn_agent``.
This new agent will run on a compute node using OVN as
network backend, similar to other ML2 mechanism drivers as ML2/OVS or
ML2/SRIOV. This new agent will perform those actions that the
ovn-controller service cannot execute.
More details in `RFE <https://bugs.launchpad.net/neutron/+bug/1998608>__`

View File

@@ -165,6 +165,7 @@ libvirt_tls: "yes"
{% if scenario == "ovn" %} {% if scenario == "ovn" %}
neutron_plugin_agent: "ovn" neutron_plugin_agent: "ovn"
neutron_ovn_distributed_fip: "yes" neutron_ovn_distributed_fip: "yes"
neutron_enable_ovn_agent: "yes"
enable_octavia: "yes" enable_octavia: "yes"
octavia_provider_drivers: "ovn:OVN provider" octavia_provider_drivers: "ovn:OVN provider"
octavia_provider_agents: "ovn" octavia_provider_agents: "ovn"

View File

@@ -346,6 +346,10 @@ neutron
[ironic-neutron-agent:children] [ironic-neutron-agent:children]
neutron neutron
[neutron-ovn-agent:children]
compute
network
# Cinder # Cinder
[cinder-api:children] [cinder-api:children]
cinder cinder