metallb-speaker

Metallb-Speaker

  • Canonical Kubernetes
Channel Revision Published Runs on
latest/stable 41 12 Jun 2023
Ubuntu 22.04 Ubuntu 20.04
latest/candidate 41 07 Jun 2023
Ubuntu 22.04 Ubuntu 20.04
latest/beta 36 21 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
latest/edge 39 22 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
1.28/candidate 41 07 Jun 2023
Ubuntu 22.04 Ubuntu 20.04
1.28/edge 39 22 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
1.27/stable 41 12 Jun 2023
Ubuntu 22.04 Ubuntu 20.04
1.27/candidate 41 12 Jun 2023
Ubuntu 22.04 Ubuntu 20.04
1.27/beta 36 10 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
1.27/edge 37 10 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
1.26/stable 32 27 Feb 2023
Ubuntu 22.04 Ubuntu 20.04
1.26/candidate 32 25 Feb 2023
Ubuntu 22.04 Ubuntu 20.04
1.26/beta 26 09 Apr 2023
Ubuntu 22.04 Ubuntu 20.04
1.26/edge 26 10 Nov 2022
Ubuntu 22.04 Ubuntu 20.04
1.25/stable 23 30 Sep 2022
Ubuntu 22.04 Ubuntu 20.04
1.25/candidate 23 28 Sep 2022
Ubuntu 22.04 Ubuntu 20.04
1.25/beta 27 01 Dec 2022
Ubuntu 22.04 Ubuntu 20.04
1.25/edge 18 08 Sep 2022
Ubuntu 22.04 Ubuntu 20.04
1.24/stable 12 04 Aug 2022
Ubuntu 22.04 Ubuntu 20.04
1.24/candidate 12 02 Aug 2022
Ubuntu 22.04 Ubuntu 20.04
1.24/beta 8 16 Jun 2022
Ubuntu 20.04
1.24/edge 13 12 Aug 2022
Ubuntu 22.04 Ubuntu 20.04
1.23/edge 4 25 Mar 2022
Ubuntu 20.04
juju deploy metallb-speaker
Show information

Platform:

About

MetalLB is a Kubernetes-aware solution that will monitor for services with the type LoadBalancer and assign them an IP address from a virtual pool.

It uses BGP(Border Gateway Protocol) or Layer 2 (with ARP Address Resolution Protocol) to expose services.

MetalLB has support for local traffic, meaning that the machine that receives the data will be the machine that services the request. It is not suggested to use a virtual IP with high traffic workloads because only one machine will receive the traffic for a service - the other machines are solely used for failover.

BGP does not have this limitation but does see nodes as the atomic unit. This means if the service is running on two of five nodes then only those two nodes will receive traffic, but they will each receive 50% of the traffic even if one of the nodes has three pods and the other only has one pod running on it. It is recommended to use node anti-affinity to prevent Kubernetes pods from stacking on a single node.

Note: For more information on configuring MetalLB with Calico in BGP mode, please see this explanation of the required configuration from the MetalLB website

Deployment

Layer 2 mode

The best way to deploy MetalLB in layer 2 mode on Charmed Kubernetes is with the MetalLB bundle, which includes Kubernetes operator charms both the controller and speaker components.

To deploy the operator, you will first need a Kubernetes model in Juju. Add your Kubernetes as a cloud to your Juju controller:

juju add-k8s k8s-cloud --controller $(juju switch | cut -d: -f1)

Next, create a new Kubernetes model:

juju add-model metallb-system k8s-cloud

Then you can deploy MetalLB:

juju deploy metallb-controller
juju deploy metallb-speaker

Configuration

You will likely want to change the IP addresses allocated to MetalLB to suit your environment. The IP addresses can be specified as a range, such as “192.168.1.88-192.168.1.89”, or as a comma-separated list of pools in CIDR notation, such as “192.168.1.240/28, 10.0.0.0/28”.

Configuring the IP addresses can be done either at time of deployment via single-line config or later by changing the charm config via Juju.

An example single-line config adjustment might look like:

juju deploy metallb-controller --config iprange='192.168.1.88-192.168.1.89'

Alternatively, you can change the config directly on the metallb-controller charm at any time:

juju config metallb-controller iprange="192.168.1.240/28, 10.0.0.0/28"

Note: Using RBAC

If RBAC is enabled in the Kubernetes cluster, an extra deployment step is required: before deploying MetalLB, you must apply the [RBAC permissions manifest][rbac-manifest]. This manifest gives permissions to the operator pods to use the Kubernetes API to create the necessary resources to make MetalLB work. You can apply the manifest using kubectl:

wget https://raw.githubusercontent.com/charmed-kubernetes/metallb-operator/master/docs/rbac-permissions-operators.yaml
kubectl apply -f rbac-permissions-operators.yaml

Be aware that the manifest has to refer to the namespace in which MetalLB is deployed. This namespace will be the same as the Juju model you deployed it into, above. If you used a model name other than metallb-system, you will need to edit the manifest before applying it.

If you forgot to apply this manifest before deploying MetalLB, the units will fail in the start hook. But don’t worry! You can apply the manifest afterwards, and then resolve the units that are in error to get them back into a working state:

juju resolve metallb-controller/0
juju resolve metallb-speaker/0

BGP mode

Since the Kubernetes operator charms for MetalLB do not yet support BGP mode, for now the recommended way to deploy MetalLB in BGP mode is to use the upstream manifests:

kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.9.3/manifests/namespace.yaml
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.9.3/manifests/metallb.yaml
# On first install only
kubectl create secret generic -n metallb-system memberlist --from-literal=secretkey="$(openssl rand -base64 128)"

Configuration

The BGP configuration can then be performed by using a MetalLB ConfigMap.

Using MetalLB

Once deployed, MetalLB will automatically assign IPs from its pools to any service of type LoadBalancer. When the services are deleted, the IPs are available again.

Testing MetalLB

To test your deployment of MetalLB, you can use the [microbot manifest][] to deploy a simple webapp with a service type of LoadBalancer:

wget https://raw.githubusercontent.com/charmed-kubernetes/metallb-operator/master/docs/example-microbot-lb.yaml
kubectl apply -f example-microbot-lb.yaml
kubectl get service microbot-lb

The EXTERNAL-IP is the IP assigned to the microbot service by the MetalLB controller. If you reach this IP with a browser, you should see the image of a microbot. If you cannot, most probably the IP range is not correctly chosen; the IP range needs to be a pool reserved solely for MetalLB to avoid IP conflicts.

To remove the test webapp and service, simply delete the manifest with kubectl:

kubectl delete -f example-microbot-lb.yaml