我有两个服务,web-service在端口80上运行,admin-service在端口8000上运行。我希望所有的http / admin请求都代理到admin-service:8000以及所有其他请求到网络服务:80。我已经尝试了下面的配置,但它似乎不起作用。我也在使用Google Kubernetes Engine。
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
知道我可能做错了吗?
答案 0 :(得分:2)
看起来不错,但是......您的管理服务是否会回复GET /admin
?除非您在入口上使用ingress.kubernetes.io/rewrite-target: /
注释,否则您需要支持后备服务中的URI
答案 1 :(得分:0)
指定默认后端的方法超出了rules
。
我认为您应该按照此处指定的规则部分使用网络服务:name-based-virtual-hosting(查找"默认后端")
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