我有两个部署,一个用于后端,一个用于前端,还有两个服务。前端服务设置为LoadBalancer,并按预期方式公开(使用minikube隧道)。后端服务不应该在群集外部公开,因此我没有设置任何类型的服务(默认为ClusterIP,仅在群集内可用)。现在,我想从前端拨打电话到后端。当我输入
kubectl exec -it FRONT_END_POD_NAME -- /bin/sh
然后使用curl
可以获取我期望的所有资源,但是,当我打开获取与我在curl中键入相同资源的网站应用程序时,控制台net::ERR_NAME_NOT_RESOLVED
中将出现错误。即使我能够从前端卷曲它并且一切正常,您是否知道为什么会发生这种情况?如何解决?
apiVersion: apps/v1
kind: Deployment
metadata:
name: backend-deployment
labels:
app: backend
spec:
selector:
matchLabels:
app: backend
replicas: 1
template:
metadata:
labels:
app: backend
spec:
containers:
- name: backend
image: ajris/site_backend:pr-kubernetes
ports:
- containerPort: 8080
====
apiVersion: v1
kind: Service
metadata:
name: backend-service
labels:
app: backend
spec:
selector:
app: backend
ports:
- protocol: TCP
port: 8081
targetPort: 8080
===
apiVersion: apps/v1
kind: Deployment
metadata:
name: frontend-deployment
labels:
app: frontend
spec:
selector:
matchLabels:
app: frontend
replicas: 1
template:
metadata:
labels:
app: frontend
spec:
containers:
- name: frontend
image: ajris/site_frontend:travis-66
ports:
- containerPort: 3000
imagePullPolicy: Always
===
apiVersion: v1
kind: Service
metadata:
name: frontend-service
labels:
app: frontend
spec:
ports:
- protocol: TCP
port: 3001
targetPort: 3000
selector:
app: frontend
type: LoadBalancer
答案 0 :(得分:1)
既然这还没有一个部分的答案,不妨让其他人在未来更容易找到它。提出问题的人在问题的评论中自己回答了这个问题。
基本上这里发生的事情是,React 不在前端 pod 上执行,而是在客户端的浏览器中执行。因此,如果客户端无法访问后端 Pod,那么任何尝试联系后端 Pod 的请求都将失败,例如具有 ClusterIP 服务的后端 Pod。
要解决此问题,需要可以从客户端访问后端服务器。这可以通过将与后端 pod 关联的服务更改为 LoadBalancer 或使用入口来完成。