k8s-安装负载均衡器
2023-09-11 14:18:11 时间
本文章是 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
相关文章
- K8S学习圣经6:资源控制+SpringCloud动态扩容原理和实操
- 在k8s集群中,如何知道某个pod ip段,是属于哪个主机的?
- linux中如何将多条命令写入在一行中,其中包括while语句,同时,在k8s的command中如何来使用
- k8s中kubeconfig的配置及使用
- k8s中初始化容器(init container)的作用及其使用方法
- k8s中configmap的作用及使用方式
- centos7安装k8s 旧版本1.5版本以及之前
- K8S通过kubelive配置VIP,以及查看可外网访问的虚拟的VIP
- 顶级工具 | Popeye帮你发现k8s集群潜在问题
- k8s踩坑记 - kubeadm join 之 token 失效
- 牛批!阿里 P8 熬夜冠军手码的 Docker 容器 +k8s 技术 PDF, 你还等啥呢
- k8s安装报错 Error: unknown flag: --experimental-upload-certs
- 安装k8s集群(亲测)
- [云原生K8S] k8s亲和、反亲和、污点、容忍
- 基于docker-k8s的web集群
- k8s - 容器类型 - logrotate日志轮转工具 - HPA的部署 - Dashboard安装部署
- k8s源码分析7-API核心服务Authorization的认证及鉴权
- kubespray续签k8s证书
- 【k8s第三步】Kubernetes-Dashboard仪表盘【已修正错误】
- 02-k8s资源管理与实战入门
- centos7.3 kubernetes/k8s 1.10 离线安装 --已验证
- k8s的 Nginx Ingress 调优
- k8s SLUB: Unable to allocate memory on node -1 错误
- k8s监控api调用
- centos7安装k8s 1.25版本 Error getting node“ err=“node “master01“ not found 需要指定 --pod-infra-container-image= 参数
- k8s CICD部署脚本
- ubuntu 20.4安装k8s 1.24.0(使用containerd)
- k8s二进制部署v1.22.15,flannel安装排错过程
- k8s图形化工具dashboard的安装、k8s图形化工具kubeoard的安装
- 【云原生】细数 k8s支持的4种类型的container
- K8S组件-----图形化web界面Dashboard搭建安装,让k8s管理更简单
- k8s集群安装