Nginx入口路径以重定向到Azure K8的多个服务 server.basePath: root_url serve_from_sub_path

问题描述

我现在正在使用天蓝色的k8。我有两个服务需要通过同一域公开,并希望为不同的服务添加路径。

入口文件如下


apiVersion: extensions/v1beta1
kind: Ingress
Metadata:
  name: kibana-ingress
  namespace : {{ .Values.namespace }}
  annotations:
    kubernetes.io/ingress.class: "Nginx"
    Nginx.ingress.kubernetes.io/affinity: "cookie"
    Nginx.ingress.kubernetes.io/session-cookie-name: "route"
    Nginx.ingress.kubernetes.io/session-cookie-hash: "sha1"
    Nginx.ingress.kubernetes.io/rewrite-target: /$2
    Nginx.ingress.kubernetes.io/use-regex: "true"
spec:
  tls:
  - hosts:
    - {{ .Values.kibana.ingressdomain }}
    secretName: abb-aks-cert
  rules:
  - host: {{ .Values.kibana.ingressdomain }}
    http:
      paths:
      - path: /app/kibana
        backend:
          serviceName: kibana-service
          servicePort: 5601
      - path: /grafana
        backend:
            serviceName: monitor-grafana
            servicePort: 80


当我这样定义时,出现404错误。有什么解决办法吗?

Kubernetes版本为1.16

解决方法

这是人们常犯的错误。 Web应用程序通常(默认情况下)使用基本路径= /。 在首次请求期间,该网站能够正确共振,但路径不正确,因为它不知道其在代理后面运行,并且某事正在重写路径。

您需要相应地设置两个应用的根/基路径,并删除重写,因为它不需要。


对于kibana,您需要设置:

server.basePath:

如果在代理后面运行,则使您能够指定安装Kibana的路径。使用server.rewriteBasePath设置告诉Kibana是否应从收到的请求中删除basePath,并在启动时防止弃用警告。此设置不能以斜杠(/)结尾。

kibana docs中的更多内容


对于grafana,您需要设置:

root_url

这是用于从Web浏览器访问Grafana的完整URL。如果您使用Google或GitHub OAuth身份验证(正确的回调URL),这一点很重要。

注意:如果您在Grafana前面有一个通过子路径公开它的反向代理,则此设置也很重要。在这种情况下,请将子路径添加到此URL设置的末尾。

serve_from_sub_path

从root_url设置中指定的子路径中提供Grafana服务。出于兼容性原因,默认情况下将其设置为false。

启用此设置并在上面的root_url中使用子路径,例如root_url = http:// localhost:3000 / grafana,可以在http:// localhost:3000 / grafana上访问Grafana

grafana docs中的更多内容