k8s部署metallb实现service的LoadBalancer模式

开启ipvs并开启严格ARP模式

参考https://metallb.io/installation/

kubectl edit configmap -n kube-system kube-proxy

mode: ""
ipvs:
  strictARP: false

改成

    mode: "ipvs"
    ipvs:
      strictARP: true

k8s原生部署metallb

下载

wget https://raw.githubusercontent.com/metallb/metallb/v0.14.8/config/manifests/metallb-native.yaml

部署

kubectl apply -f metallb-native.yaml 

helm方式部署metallb

helm repo add metallb https://metallb.github.io/metallb
helm repo update

helm search repo metallb/metallb -l

kubectl create ns metallb-ns
helm install metallb metallb/metallb --namespace=metallb-ns --version 0.14.8

这个命令helm install metallb metallb/metallb --namespace=metallb-ns --version 0.14.8可能下载metallb失败;可以通过其他方式下载后再安装

wget https://github.com/metallb/metallb/releases/download/metallb-chart-0.14.8/metallb-0.14.8.tgz
tar -zxvf metallb-0.14.8.tgz
cd metallb/
kubectl create ns metallb-ns
helm install metallb . --namespace=metallb-ns
kubectl get all -n metallb-ns 

使用metallb

创建一个IPAddressPool地址池,用来指定用于分配的IP池;再创建了一个二层通告,去关联这个地址池将其中的IP地址们通告出去

ip-pool.yaml

apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
  name: production-public-ips
  namespace: metallb-ns
spec:
  addresses:
  - 192.168.10.0/24

---
apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:
  name: production-adver
  namespace: metallb-ns
spec:
  ipAddressPools:
  - production-public-ips

kubectl apply -f ip-pool.yaml

部署一个nginx

nginx-deployment.yaml

kind: Deployment
apiVersion: apps/v1
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
        - name: nginx
          image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/nginx:1.27.1
          ports:
            - name: web
              containerPort: 80

kubectl apply -f nginx-deployment.yaml

nginx-service.yaml

apiVersion: v1
kind: Service
metadata:
  name: nginx
  annotations:
    metallb.universe.tf/address-pool: production-public-ips #添加注解,指定地址池
spec:
  ports:
  - port: 80
    targetPort: 80
  selector:
    app: nginx
  type: LoadBalancer  #需要指定为LoadBalancer类型

kubectl apply -f nginx-service.yaml

查看分配的ip

kubectl get svc

结果

NAME         TYPE           CLUSTER-IP      EXTERNAL-IP    PORT(S)        AGE
kubernetes   ClusterIP      10.96.0.1       <none>         443/TCP        76d
nginx        LoadBalancer   10.102.47.232   192.168.10.0   80:32195/TCP   41s

向nginx容器里的静态目录写入内容

kubectl exec -it nginx-7ccbfc6ff8-x9dx6 -- /bin/sh -c "echo i like metallb > /usr/share/nginx/html/metallb.html"

访问http://192.168.10.0/metallb.html

卸载metallb

原生方式

kubectl delete -f metallb-native.yaml 

helm方式

helm uninstall metallb --namespace=metallb-ns

参考

https://metallb.io/installation/
https://blog.csdn.net/weixin_64334766/article/details/134818813
https://www.cnblogs.com/bmwhero/p/17950012
相关推荐
丶21368 分钟前
【云原生】云原生后端详解:架构与实践
后端·云原生·架构
小森饭27 分钟前
Kubernetes运行大数据组件-运行hive
大数据·hive·云原生·kubernetes
白总Server1 小时前
孤岛架构与微服务架构区别
java·开发语言·后端·微服务·云原生·架构·scala
丶21363 小时前
【云原生】云原生后端:监控与观察性
后端·云原生·架构
pyliumy3 小时前
docker的安装配置与基本简单命令
运维·docker·容器
winkee3 小时前
Skopeo 工具介绍
docker·容器·devops
CopyLower3 小时前
ZooKeeper的应用场景:深入探讨分布式系统中的多样化应用
分布式·zookeeper·云原生
test12804 小时前
局域网 docker pull 使用代理拉取镜像
docker·容器·代理·docker pull·http_proxy
天幕繁星5 小时前
docker占用磁盘过多问题
docker·容器
bala55696 小时前
Docker-在Centos中部署Shell脚本获取镜像并构建容器
linux·阿里云·docker·容器·centos·maven