1

我有两个服务,web-service 在端口 80 上运行,admin-service 在端口 8000 上运行。我希望所有 http /admin 请求都被代理到 admin-service:8000 和所有其他请求去 web-服务: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

知道我可能做错了什么吗?

4

2 回答 2

2

看起来不错,但是...您的管理服务是否响应GET /admin?因为除非您ingress.kubernetes.io/rewrite-target: /在入口处使用注释,否则您需要在后端服务中支持 URI

于 2018-02-03T00:48:03.810 回答
0

指定默认后端的方法是在rules.

我认为您应该将 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
于 2018-02-04T18:43:23.607 回答