The module is not enabled by default in any bundles.
The module is configured using the ModuleConfig custom resource named metallb (learn more about setting up Deckhouse…).
Example of the ModuleConfig/metallb resource for configuring the module:
apiVersion: deckhouse.io/v1alpha1
kind: ModuleConfig
metadata:
  name: metallb
spec:
  version: 1
  enabled: true
  settings: # <-- Module parameters from the "Parameters" section below.
Parameters
Schema version: 1
Examples:
bgpPeers:
- peer-address: 192.168.1.1
  peer-asn: 1111
  my-asn: 2222
  source-address: 192.168.1.2
  hold-time: 10s
  node-selector:
    matchLabels:
      node: test
addressPools:
- name: my-pool-bgp
  protocol: bgp
  addresses:
  - 192.168.100.1-192.168.100.10
  - 192.168.101.0/24
  bgp-advertisements:
  - aggregation-length: 32
    localpref: 100
    communities:
    - no-advertise
bgpCommunities:
  no-advertise: 65535:65282
speaker:
  nodeSelector:
    mylabel: speaker
addressPools:
- name: my-pool-l2
  protocol: layer2
  addresses:
  - 192.168.100.1-192.168.100.10
  - 192.168.101.0/24
speaker:
  nodeSelector:
    mylabel: speaker
  tolerations:
  - key: dedicated
    operator: Equal
    value: speaker
- array of objectsaddressPoolsRequired value A list of IP ranges to assign to services. Format — a data array similar to that of MetalLB’s. Default: []- array of stringsaddressPools.addressesA list of ranges, where each range can look like a subnet/mask or a numeric address range (with “-“ as a delimiter). 
- booleanaddressPools.auto-assignAuto-assign flag used to prevent MetallB from automatic allocation for a pool. Default: true
- booleanaddressPools.avoid-buggy-ipsPrevents addresses ending with .0and.255to be used by a pool.Default: false
- array of objectsaddressPools.bgp-advertisementsDefines BGP advertisements. - integeraddressPools.bgp-advertisements.aggregation-lengthThe aggregation-length advertisement option lets you “roll up” prefix into a larger one. Works for IPv4 addresses. Default: 32Allowed values: 1 <= X
- array of stringsaddressPools.bgp-advertisements.communitiesKeys from the bgpCommunities parameter to be associated with the announcement. Example: communities: - no-advertise
- integeraddressPools.bgp-advertisements.localprefThe BGP LOCAL_PREFattribute which is used by BGP best path algorithm.Path with higher localpref is preferred over one with lower localpref. 
 
- stringaddressPools.nameThe name of the pool (you can specify it using the service annotation as follows: metallb.universe.tf/address-pool: <name>). It should conform to RFC 1123: dot-separated parts in lowercase, consists of alphanumeric characters, ‘-‘. Each part must start and end with an alphanumeric character.Pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$
- stringaddressPools.protocolThe protocol used by the speaker to announce services. Allowed values: bgp,layer2
 
- objectbgpCommunitiesThe BGP communities list. Example: bgpCommunities: no-advertise: 65535:65282
- array of objectsbgpPeersA list of external BGP routers to use with the module. Format — a data array similar to that of MetalLB’s. The parameter is optional if only the layer2mode is used to announce services.Default: []- integer or stringbgpPeers.hold-timeThe timeout after which the neighboring BGP peer is considered dead. This value is divided by three to get the keep-alive interval. The recommended value is 3s(i.e., keep-alive packets are sent once per second). Note that the BGP protocol does not support values lower than this. By default, the parameter is set to90s(i.e., keep-alive packets are sent every 30 seconds).Pattern: ^(0|(([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?)$
- integerbgpPeers.my-asnRequired value The AS number in the cluster. Allowed values: 0 <= X <= 4294967295
- objectbgpPeers.node-selectorThe additional pseudo-selector implemented by the speaker application. It selects nodes that are allowed to connect to external BGP routers. Do not confuse it with speaker.nodeSelectorandnodeSelector.An optional parameter. The format is matchLabelsormatchExpressions.- array of objectsbgpPeers.node-selector.matchExpressions- stringbgpPeers.node-selector.matchExpressions.key
- stringbgpPeers.node-selector.matchExpressions.operator
- array of stringsbgpPeers.node-selector.matchExpressions.values
 
- objectbgpPeers.node-selector.matchLabels
 
- stringbgpPeers.passwordAuthentication password for routers enforcing TCP MD5 authenticated sessions. 
- stringbgpPeers.peer-addressRequired value The IP address of the external BGP router. Pattern: ^([0-9]{1,3}\.){3}[0-9]{1,3}$
- integerbgpPeers.peer-asnRequired value The AS number on the external BGP router. Allowed values: 0 <= X <= 4294967295
- integerbgpPeers.peer-portPort to dial when establishing the session. Default: 179Allowed values: 0 <= X <= 16384
- stringbgpPeers.router-idBGP router ID to advertise to the peer. 
- stringbgpPeers.source-addressThe source IP address for outbound connections. Pattern: ^(?:[0-9]{1,3}\.){3}[0-9]{1,3}$
 
- objectnodeSelectorA selector for the main controller. It is the same as the Pod’s spec.nodeSelectorparameter in Kubernetes.If the parameter is omitted or false, it will be determined automatically.
- objectspeakerParameters of the speakercomponent, which announces services (usingbgporlayer2(LVS) routing protocol) and routes application traffic to its node.- objectspeaker.nodeSelectorRequired value A selector for the speaker DaemonSet. It is the same as the Pod’s spec.nodeSelectorparameter in Kubernetes.If the parameter is omitted or false, it will be determined automatically.
- array of objectsspeaker.tolerationsTolerations for the speaker DaemonSet. They are the same as the Pod’s spec.tolerationsparameter in Kubernetes.If the parameter is omitted or false, it will be determined automatically.- stringspeaker.tolerations.effect
- stringspeaker.tolerations.key
- stringspeaker.tolerations.operator
- integerspeaker.tolerations.tolerationSeconds
- stringspeaker.tolerations.value
 
 
- array of objectstolerationsTolerations for the main controller. They are the same as the Pod’s spec.tolerationsparameter in Kubernetes.If the parameter is omitted or false, it will be determined automatically.- stringtolerations.effect
- stringtolerations.key
- stringtolerations.operator
- integertolerations.tolerationSeconds
- stringtolerations.value