k8s-安装负载均衡器

本文章是 k8s二进制高可用集群部署 的分支。详细步骤请参考目录。 

  k8s的LoadBalancer类型的Service依赖于外部的云提供的Load Balancer。

  当我们把k8s部署在裸机上面时,或者是测试环境时,需要简单的LoadBalancer来验证工作.

  目前开源市场有三款知名的负载均衡器,本文以MetalLB为例。

  MetalLB为本地运行的Kubernetes集群提供了LoadBalance功能,使用户像在公有云环境一样,使用K8S的LoadBalancer Service。

  参考地址:https://metallb.universe.tf/installation/

1.准备

  如果您在 IPVS 模式下使用 kube-proxy,从 Kubernetes v1.14.2 开始,您必须启用严格的 ARP 模式。

  请注意,如果您使用 kube-router 作为服务代理,则不需要它,因为它默认启用严格的 ARP。

  您可以通过在当前集群中编辑 kube-proxy 配置来实现此目的:

kubectl edit configmap -n kube-system kube-proxy

  并设置:

apiVersion: kubeproxy.config.k8s.io/v1alpha1
kind: KubeProxyConfiguration
mode: "ipvs"
ipvs:
  strictARP: true

  ---您还可以将此配置片段添加到您的 kubeadm-config 中,只需在主配置之后附加它即可。

  如果您正在尝试自动执行此更改,这些 shell 代码段可能会帮助您:

# see what changes would be made, returns nonzero returncode if different
kubectl get configmap kube-proxy -n kube-system -o yaml | \
sed -e "s/strictARP: false/strictARP: true/" | \
kubectl diff -f - -n kube-system

# actually apply the changes, returns nonzero returncode on errors only
kubectl get configmap kube-proxy -n kube-system -o yaml | \
sed -e "s/strictARP: false/strictARP: true/" | \
kubectl apply -f - -n kube-system

2.安装【建议将资源文件下载后应用】

kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.13.9/config/manifests/metallb-native.yaml

3.配置

cat > /home/kubernetes/metailb-layer2-config.yaml  << "EOF"
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
  name: first-pool
  namespace: metallb-system
spec:
  addresses:
  - 192.168.64.245-192.168.64.250

---

apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:
  name: example
  namespace: metallb-system
spec:
  ipAddressPools:
  - first-pool
EOF
kubectl apply -f /home/kubernetes/metailb-layer2-config.yaml

 

posted @ 2023-03-04 11:25  SpringCore  阅读(437)  评论(0编辑  收藏  举报