提问者:小点点

在带有WSL2的minikube上,负载均衡器或节点端口不起作用,但kubectl暴露工作良好


我在WSL2上使用了minikube。我部署了一个简单的烧瓶应用程序映像并编写了一个LoadBalancer来公开服务。

我的问题是,如何修改服务清单以获得与公开相同的结果?

以下是更多详细信息。

烧瓶应用程序部署yaml。

rss. yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: esg
spec:
  selector:
    matchLabels:
      app: rss
  replicas: 3
  template:
    metadata:
      labels:
        app: rss
    spec: 
      containers:
      - name: rss
        image: "idioluck/00esg_rss:v01"
        ports:
        - containerPort: 5000

服务yaml(我也尝试了nodeport和loadbalanacer。)

rss_lb. yaml

apiVersion: v1
kind: Service
metadata:
  name: esg-lb
spec:
  type: NodePort # LoadBalancer
  selector:
    app: rss  
  ports:
  - protocol: TCP
    port: 8080 
    targetPort: 5000

kubectl命令是

sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl apply -f rss.yaml
deployment.apps/esg created
sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl apply -f rss_lb.yaml
service/esg-lb created
sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl get pods
NAME                  READY   STATUS    RESTARTS   AGE
esg-757f659b4-4vndc   1/1     Running   0          13s
esg-757f659b4-4wd2w   1/1     Running   0          13s
esg-757f659b4-sf5q6   1/1     Running   0          13s
sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl get all
NAME                      READY   STATUS    RESTARTS   AGE
pod/esg-757f659b4-4vndc   1/1     Running   0          16s
pod/esg-757f659b4-4wd2w   1/1     Running   0          16s
pod/esg-757f659b4-sf5q6   1/1     Running   0          16s

NAME                 TYPE           CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
service/esg-lb       LoadBalancer   10.101.221.26   <pending>     8080:31308/TCP   8s
service/kubernetes   ClusterIP      10.96.0.1       <none>        443/TCP          23h

NAME                  READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/esg   3/3     3            3           16s

NAME                            DESIRED   CURRENT   READY   AGE
replicaset.apps/esg-757f659b4   3         3         3       16s

外部IP正在等待。所以我删除loabdbalancer并使用暴露

sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl expose deployment esg --type=LoadBalancer --port=8080
service/esg exposed
sjw@DESKTOP-MFPNHRC:~/esg_kube/kubesvc/rss$ kubectl get svc
NAME         TYPE           CLUSTER-IP     EXTERNAL-IP   PORT(S)          AGE
esg          LoadBalancer   10.99.208.98   127.0.0.1     8080:30929/TCP   46s
kubernetes   ClusterIP      10.96.0.1      <none>        443/TCP          23h

服务已成功暴露。且服务为负载均衡器。


共1个答案

匿名用户

您的LoadBalancer类型服务将Pending显示为状态,因为它正在等待您配置外部负载均衡器,如AWS的弹性负载均衡器或GCP的负载均衡器。负载均衡器类型的服务通常与托管库伯内特斯服务一起使用,例如EKS、GKE等。

另一方面,您可以公开您的服务,因为它已经分配了grousterIP

如果你想在Minikube中使用LB,这个官方文档可能会对你有所帮助。否则,你可以直接使用NodePort类型服务来公开你的烧瓶应用。