访问部署在Kubernetes上的应用程序

问题描述 投票:0回答:2

我的图像托管在 GCR 上。 我在本地 Kubernetes 集群(mac)上部署了我的应用程序。 这是我的部署文件 -

apiVersion: apps/v1
kind: Deployment
metadata:
  name: sv-premier
spec:
  selector:
    matchLabels:
      app: sv-premier
  template:
    metadata:
      labels:
        app: sv-premier
    spec:
      volumes:
      - name: google-cloud-key
        secret:
          secretName: gcp-key
      containers:
      - name: sv-premier
        image: gcr.io/proto/premiercore1:latest
        imagePullPolicy: Always
        command: ["echo", "Done deploying sv-premier"]
        volumeMounts:
        - name: google-cloud-key
          mountPath: /var/secrets/google
        env:
        - name: GOOGLE_APPLICATION_CREDENTIALS
          value: /var/secrets/google/key.json
        ports:
        - containerPort: 8080
      imagePullSecrets:
      - name: imagepullsecretkey

我正在尝试访问该应用程序,但无法访问。 我将服务创建为 -->

$ kubectl expose deployment sv-premier --port=8080 --target-port=8080
service/sv-premierleague exposed

$ kubectl get service sv-premier
NAME         TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGE
sv-premier   ClusterIP   10.107.202.156   <none>        8080/TCP   58s

$ kubectl 获取所有 -o 宽

NAME                              READY   STATUS    RESTARTS   AGE   IP          NODE             NOMINATED NODE   READINESS GATES
pod/sv-premier-6b695d5fd7-l4995   1/1     Running   0          21h   10.1.0.45   docker-desktop   <none>           <none

NAME                 TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGE   SELECTOR
service/kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP    8d    <none>
service/sv-premier   ClusterIP   10.107.202.156   <none>        8080/TCP   23m   app=sv-premier

NAME                         READY   UP-TO-DATE   AVAILABLE   AGE   CONTAINERS   IMAGES                                    SELECTOR
deployment.apps/sv-premier   1/1     1            1           21h   sv-premier   gcr.io/sap-s4-proto/premiercore1:latest   app=sv-premier


NAME                                    DESIRED   CURRENT   READY   AGE   CONTAINERS   IMAGES                                    SELECTOR
replicaset.apps/sv-premier-6b695d5fd7   1         1         1       21h   sv-premier   gcr.io/sap-s4-proto/premiercore1:latest   app=sv-premierleague,pod-template-hash=6b695d5fd7

$ kubectl 获取节点 -o 宽

NAME             STATUS   ROLES    AGE   VERSION   INTERNAL-IP    EXTERNAL-IP   OS-IMAGE         KERNEL-VERSION     CONTAINER-RUNTIME
docker-desktop   Ready    master   8d    v1.15.5   192.168.65.3   <none>        Docker Desktop   4.19.76-linuxkit   docker://19.3.5

现在正如所接受的答案中提到的here,我正在尝试访问我的应用程序,例如-- docker-desktop:NodePort 即 192.168.65.3:8080。但我做不到。

kubernetes kubectl
2个回答
2
投票

更新您的命令以包含在节点端口上公开服务的类型

kubectl expose deployment sv-premier --port=8080 --type=NodePort

那么你应该尝试使用 .. ip:nodeport 组合来访问服务

您使用谷歌云吗?您应该更喜欢的服务类型=负载均衡器

当您创建 LoadBalancer 类型的服务时,Google Cloud 控制器会自动配置网络负载均衡器。等待控制器配置网络负载均衡器并生成稳定的 IP 地址。使用负载均衡器中的详细信息来访问服务。


0
投票

是的,我面临着同样的问题,任何人都可以解决这个问题,如果有人知道请回复我。 电子邮件:[电子邮件受保护]

© www.soinside.com 2019 - 2024. All rights reserved.