Kubernetes的新手,遇到一个问题,当我尝试点击api时遇到了502错误的网关。
我的配置看起来像这样
apiVersion: v1
kind: Service
metadata:
name: api-cluster-ip-service
spec:
type: ClusterIP
selector:
component: api
ports:
- port: 80
targetPort: 5000
apiVersion: apps/v1
kind: Deployment
metadata:
name: api-deployment
spec:
replicas: 1
selector:
matchLabels:
component: api
template:
metadata:
labels:
component: api
spec:
containers:
- name: books-api
image: mctabor/books-api
ports:
- containerPort: 5000
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: books-ingress-service
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/rewrite-target: /$1
spec:
rules:
- http:
paths:
- path: /api/?(.*)
backend:
serviceName: api-cluster-ip-service
servicePort: 80
在我的烧瓶应用程序中,我有以下内容:
if __name__ == "__main__":
app.run(host='0.0.0.0', port=5000)
不知道我在哪里错了
我的minikube ip是192.168.99.104,我正在尝试访问192.168.99.104/api/status的api路由
答案 0 :(得分:1)
您没有正确公开服务。首先,类型 ClusterIP 的服务仅在群集内可用。使用minikube时,应尝试更改类型 NodePort 。
第二位,在yaml中声明的 port 是使服务对集群中的其他服务可见的端口。
创建NodePort服务后,执行kubectl get svc
以查看分配给该服务的外部端口。您会看到类似 80:30351 / TCP 的内容。这意味着您可以通过 192.168.99.104:30351 访问该服务。
This是解释如何在minikube中公开服务的好答案