我的图像托管在 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。但我做不到。
更新您的命令以包含在节点端口上公开服务的类型
kubectl expose deployment sv-premier --port=8080 --type=NodePort
那么你应该尝试使用 .. ip:nodeport 组合来访问服务
您使用谷歌云吗?您应该更喜欢的服务类型=负载均衡器
当您创建 LoadBalancer 类型的服务时,Google Cloud 控制器会自动配置网络负载均衡器。等待控制器配置网络负载均衡器并生成稳定的 IP 地址。使用负载均衡器中的详细信息来访问服务。
是的,我面临着同样的问题,任何人都可以解决这个问题,如果有人知道请回复我。 电子邮件:[电子邮件受保护]