# ovn controller # == Class: ovn::controller # # installs ovn and starts the ovn-controller service # # === Parameters: # # [*ovn_remote*] # (Required) URL of the remote ovn southbound db. # Example: 'tcp:127.0.0.1:6642' # # [*ovn_encap_type*] # (Optional) The encapsulation type to be used # Defaults to 'geneve' # # [*ovn_encap_ip*] # (Required) IP address of the hypervisor(in which this module is installed) to which # the other controllers would use to create a tunnel to this controller # # [*ovn_encap_tos*] # (Optional) The value to be applied to OVN tunnel interface's option:tos. # Defaults to undef # # [*ovn_bridge_mappings*] # (optional) List of : # Defaults to empty list # # [*bridge_interface_mappings*] # (optional) List of : when doing bridge mapping # Defaults to empty list # # [*hostname*] # (optional) The hostname to use with the external id # Defaults to $::fqdn # # [*ovn_bridge*] # (optional) Name of the integration bridge. # Defaults to 'br-int' # # [*mac_table_size*] # Set the mac table size for the provider bridges if defined in ovn_bridge_mappings # Defaults to undef # # [*datapath_type*] # (optional) Datapath type for ovs bridges # Defaults to undef # # [*enable_dpdk*] # (optional) Enable or not DPDK with OVS # Defaults to false. # # [*ovn_cms_options*] # (optional) A list of options that will be consumed by the CMS Plugin and # which specific to this particular chassis. # Defaults to undef # # [*ovn_remote_probe_interval*] # (optional) Set probe interval, based on user configuration, value is in ms # Defaults to 60000 # # [*ovn_openflow_probe_interval*] # (optional) The inactivity probe interval of the OpenFlow # connection to the OpenvSwitch integration bridge, in # seconds. If the value is zero, it disables the connection keepalive feature. # If the value is nonzero, then it will be forced to a value of at least 5s. # Defaults to 60 # # [*ovn_transport_zones*] # (optional) List of the transport zones to which the chassis belongs to. # Defaults to empty list # # [*enable_ovn_match_northd*] # (optional) When set to true, enable update of ovn_controller after # ovn-northd by blocking new message from the ovn-northd to be # accepted by the ovn_controller until they have the same version. # This need >= ovn2.13-20.09.0-17. # Default to false (keep the original behavior) # # [*ovn_chassis_mac_map*] # (optional) A list or a hash of key-value pairs that map a chassis specific mac to # a physical network name. An example value mapping two chassis macs to # two physical network names would be: # physnet1:aa:bb:cc:dd:ee:ff,physnet2:a1:b2:c3:d4:e5:f6 or # { # physnet1 => aa:bb:cc:dd:ee:ff, # physnet2 => a1:b2:c3:d4:e5:f6 # } # These are the macs that ovn-controller will replace a router port # mac with, if packet is going from a distributed router port on # vlan type logical switch. # Defaults to empty list # # [*ovn_monitor_all*] # (optional) A boolean value that tells if ovn-controller should monitor all # records of tables in ovs-database. If set to false, it will conditionally # monitor the records that is needed in the current chassis. # Default to false (keep the original behavior) # # [*manage_ovs_bridge*] # (optional) Create ovs bridges according to ovn_bridge_mappings. # Defaults to true # class ovn::controller( $ovn_remote, $ovn_encap_ip, $ovn_encap_type = 'geneve', $ovn_encap_tos = undef, $ovn_bridge_mappings = [], $bridge_interface_mappings = [], $hostname = $::fqdn, $ovn_bridge = 'br-int', $mac_table_size = undef, $datapath_type = undef, $enable_dpdk = false, $ovn_cms_options = undef, $ovn_remote_probe_interval = 60000, $ovn_openflow_probe_interval = 60, $ovn_transport_zones = [], $enable_ovn_match_northd = false, $ovn_chassis_mac_map = [], $ovn_monitor_all = false, $manage_ovs_bridge = true ) { include ovn::params if $enable_dpdk and (is_service_default($datapath_type) or !$datapath_type) { fail('Datapath type must be set when DPDK is enabled') } if $enable_dpdk { require vswitch::dpdk } else { require vswitch::ovs } include stdlib validate_legacy(String, 'validate_string', $ovn_remote) validate_legacy(String, 'validate_string', $ovn_encap_ip) service { 'controller': ensure => true, name => $::ovn::params::ovn_controller_service_name, hasstatus => $::ovn::params::ovn_controller_service_status, pattern => $::ovn::params::ovn_controller_service_pattern, enable => true, subscribe => Vs_config['external_ids:ovn-remote'] } package { $::ovn::params::ovn_controller_package_name: ensure => present, name => $::ovn::params::ovn_controller_package_name, before => Service['controller'] } $config_items = { 'external_ids:ovn-remote' => { 'value' => $ovn_remote }, 'external_ids:ovn-encap-type' => { 'value' => $ovn_encap_type }, 'external_ids:ovn-encap-ip' => { 'value' => $ovn_encap_ip }, 'external_ids:hostname' => { 'value' => $hostname }, 'external_ids:ovn-bridge' => { 'value' => $ovn_bridge }, 'external_ids:ovn-remote-probe-interval' => { 'value' => $ovn_remote_probe_interval }, 'external_ids:ovn-openflow-probe-interval' => { 'value' => $ovn_openflow_probe_interval }, 'external_ids:ovn-monitor-all' => { 'value' => $ovn_monitor_all }, } if $ovn_cms_options { $cms_options = { 'external_ids:ovn-cms-options' => { 'value' => join(any2array($ovn_cms_options), ',') } } } else { $cms_options = { 'external_ids:ovn-cms-options' => { 'ensure' => 'absent' } } } if $ovn_encap_tos { $encap_tos = { 'external_ids:ovn-encap-tos' => { 'value' => $ovn_encap_tos } } } else { $encap_tos = { 'external_ids:ovn-encap-tos' => { 'ensure' => 'absent' } } } if !empty($ovn_chassis_mac_map) { if $ovn_chassis_mac_map =~ Hash { $chassis_mac_map = { 'external_ids:ovn-chassis-mac-mappings' => { 'value' => join(join_keys_to_values($ovn_chassis_mac_map, ':'), ',') } } } else { $chassis_mac_map = { 'external_ids:ovn-chassis-mac-mappings' => { 'value' => join(any2array($ovn_chassis_mac_map), ',') } } } } else { $chassis_mac_map = { 'external_ids:ovn-chassis-mac-mappings' => { 'ensure' => 'absent' } } } if !empty($ovn_bridge_mappings) { $bridge_items = { 'external_ids:ovn-bridge-mappings' => { 'value' => join(any2array($ovn_bridge_mappings), ',') } } if $manage_ovs_bridge { ovn::controller::bridge { $ovn_bridge_mappings: mac_table_size => $mac_table_size, before => Service['controller'], require => Service['openvswitch'] } ovn::controller::port { $bridge_interface_mappings: before => Service['controller'], require => Service['openvswitch'] } } } else { $bridge_items = { 'external_ids:ovn-bridge-mappings' => { 'ensure' => 'absent' } } } if !empty($ovn_transport_zones) { $tz_items = { 'external_ids:ovn-transport-zones' => { 'value' => join(any2array($ovn_transport_zones), ',') } } } else { $tz_items = { 'external_ids:ovn-transport-zones' => { 'ensure' => 'absent' } } } if is_service_default($datapath_type) { warning('Usage of $::os_service_default has been deprecated. Use undef instead') $datapath_config = { 'external_ids:ovn-bridge-datapath-type' => { 'ensure' => 'absent' } } } elsif $datapath_type { $datapath_config = { 'external_ids:ovn-bridge-datapath-type' => { 'value' => $datapath_type } } } else { $datapath_config = { 'external_ids:ovn-bridge-datapath-type' => { 'ensure' => 'absent' } } } $ovn_match_northd = { 'external_ids:ovn-match-northd-version' => { 'value' => $enable_ovn_match_northd } } create_resources( 'vs_config', merge($config_items, $cms_options, $encap_tos, $chassis_mac_map, $bridge_items, $tz_items, $datapath_config, $ovn_match_northd) ) Vs_config<||> -> Service['controller'] }