如何配置Kubernetes Ingress控制器以支持两种服务?

时间:2018-02-02 23:53:34

标签: kubernetes google-kubernetes-engine kubernetes-networkpolicy

我有两个服务,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

知道我可能做错了吗?

2 个答案:

答案 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