如何配置Kubernetes入口控制器以支持两种服务?
我有两个服务,web服务在端口80上运行,管理服务在端口8000上运行。我希望所有http/admin请求都被代理到admin service:8000,所有其他请求都被代理到web service:80。我尝试了下面的配置,但似乎不起作用。我也在使用谷歌Kubernetes引擎如何配置Kubernetes入口控制器以支持两种服务?,kubernetes,google-kubernetes-engine,kubernetes-networkpolicy,Kubernetes,Google Kubernetes Engine,Kubernetes Networkpolicy,我有两个服务,web服务在端口80上运行,管理服务在端口8000上运行。我希望所有http/admin请求都被代理到admin service:8000,所有其他请求都被代理到web service:80。我尝试了下面的配置,但似乎不起作用。我也在使用谷歌Kubernetes引擎 apiVersion: extensions/v1beta1 kind: Ingress metadata: name: ingress-rules annotations: kubernetes.io
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: ingress-rules
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.org/redirect-to-https: "True"
spec:
tls:
- secretName: tls-secret
rules:
- http:
paths:
- path: /admin
backend:
serviceName: admin-service
servicePort: 8000
- path: /
backend:
serviceName: web-service
servicePort: 80
知道我做错了什么吗?看起来不错,但是。。。您的管理员服务是否响应
GET/admin
?原因除非您在入口上使用ingres.kubernetes.io/rewrite-target://
注释,否则您需要在备份服务中支持URI指定默认后端的方式超出了规则
我认为您应该在这里指定的规则部分之外使用web服务:(查找“默认后端”)
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: ingress-rules
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.org/redirect-to-https: "True"
spec:
tls:
- secretName: tls-secret
backend:
serviceName: web-service
servicePort: 80
rules:
- http:
paths:
- path: /admin
backend:
serviceName: admin-service
servicePort: 8000