gpt4 book ai didi

ssl - 路径在 Kubernetes NGINX 入口 Controller 中不起作用

转载 作者:太空宇宙 更新时间:2023-11-03 14:25:39 25 4
gpt4 key购买 nike

我有一个 Spring Boot 应用程序负责获取公民和一个配置了 ssl-passthrough 的 NGINX Ingress Controller 以将我的集群暴露给外部。

当我这样做时: https://myhostname.com/citizens

它完美地工作。这是我正在使用的配置:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: nginx-ingress
namespace: default
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/ssl-passthrough: "true"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
spec:
rules:
- host: myhostname.com
http:
paths:
- path: /
backend:
serviceName: myservice
servicePort: 443

但是我想要这样的东西:

https://myhostname.com/myservice/citizens

这将类似于 kubernetes 文档中描述的数学简单扇出方法: https://kubernetes.io/docs/concepts/services-networking/ingress/#simple-fanout

因此,在我的 Spring 应用程序中,我配置了一个 contextPath,所以在本地我会这样做: https://localhost:8080/myservice/citizens

我得到了想要的结果

对于 NGINX,我设置了以下内容:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: nginx-ingress
namespace: default
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/ssl-passthrough: "true"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/rewrite-target: /
spec:
rules:
- host: myhostname.com
http:
paths:
- path: /myservice
backend:
serviceName: myservice
servicePort: 443

我做错了什么?


解决方案:我进行了一些研究,我意识到我试图实现的方法无法通过 ssl-passthrough 实现,因为代理是盲目的,它不知道路由流量的路径。

因此,解决方案是使用子域而不是路径,因为借助 SNI 协议(protocol),NGINX Controller 将知道客户端尝试连接到哪个主机名。

最终的解决方案类似于 this

最佳答案

如果你的后端需要整个路径 /myservice/citizens 你可以直接使用它指向服务而不需要 rewrite-target 指令,因为它是 only dictates how URIs are going to be treated in the backend :

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: nginx-ingress
namespace: default
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/ssl-passthrough: "true"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
spec:
rules:
- host: myhostname.com
http:
paths:
- path: /myservice/citizens
backend:
serviceName: myservice
servicePort: 443

请注意,这假定您的服务能够将请求重定向到 8080,这是您的后端监听端口,因此它必须与之匹配。

关于ssl - 路径在 Kubernetes NGINX 入口 Controller 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57481168/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com