Load Balancer support is implemented in the Cloud Controller as of
version v1.6.0. For using the Hetzner Cloud Load Balancers you need to
deploy a Service
of type LoadBalancer
.
apiVersion: v1
kind: Service
metadata:
name: example-service
annotations:
load-balancer.hetzner.cloud/location: hel1
spec:
selector:
app: example
ports:
- port: 80
targetPort: 8080
type: LoadBalancer
The sample service will create a Load Balancer in the location hel1
with a service with listen_port = 80
and destination_port = 8080
. So
every traffic that arrives at the Load Balancer on Port 80 will be
routed to the public interface of the targets on port 8080. You can
change the behavior of the Load Balancer by specifying more annotations.
A list of all available annotations can be found on
pkg.go.dev.
If you have the cloud controller deployed with Private Network Support,
we attach the Load Balancer to the specific network automatically. You
can specifiy with an annotation that the Load Balancer should use the
private network instead of the public network.
apiVersion: v1
kind: Service
metadata:
name: example-service
annotations:
load-balancer.hetzner.cloud/location: hel1
load-balancer.hetzner.cloud/use-private-ip: "true"
spec:
selector:
app: example
ports:
- port: 80
targetPort: 8080
type: LoadBalancer
For IPVS based plugins (kube-router, kube-proxy in ipvs mode, etc...) make sure you supply 'load-balancer.hetzner.cloud/disable-private-ingress: "true"' annotation to your service or set "HCLOUD_LOAD_BALANCERS_DISABLE_PRIVATE_INGRESS" environment variable to true on hcloud-controller-manager deployment as mentioned in a paragraph below. Otherwise, network plugin installs load balancer's IP address on system's dummy interface effectively looping IPVS system in a cycle. In such scenario cluster nodes won't ever pass load balancer's health probes
For convenvience, you can set the following environment variables as cluster-wide defaults, so you don't have to set them on each load balancer service. If a load balancer service has the corresponding annotation set, it overrides the default.
HCLOUD_LOAD_BALANCERS_LOCATION
(mutually exclusive withHCLOUD_LOAD_BALANCERS_NETWORK_ZONE
)HCLOUD_LOAD_BALANCERS_NETWORK_ZONE
(mutually exclusive withHCLOUD_LOAD_BALANCERS_LOCATION
)HCLOUD_LOAD_BALANCERS_DISABLE_PRIVATE_INGRESS
HCLOUD_LOAD_BALANCERS_USE_PRIVATE_IP
HCLOUD_LOAD_BALANCERS_ENABLED