nginx - Kubernetes - 一个入口中的多个配置
问题描述
我在同一个 Kubernetes 集群中运行不同的应用程序。
我希望多个域访问我的 Kubernetes 集群并根据域进行重定向。对于每个域,我想要不同的注释/配置。
没有注释,我有一个入口部署,例如:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: frontdoor
namespace: myapps
annotations:
kubernetes.io/ingress.class: nginx
cert-manager.io/cluster-issuer: letsencrypt-prod
spec:
type: LoadBalancer
tls:
- hosts:
- foo.bar.dev
- bar.foo.dev
secretName: tls-secret
rules:
- host: foo.bar.dev
http:
paths:
- backend:
serviceName: foobar
servicePort: 9000
path: /(.*)
- host: bar.foo.dev
http:
paths:
- backend:
serviceName: varfoo
servicePort: 80
path: /(.*)
但是它们需要有多个配置,例如一个需要有以下注解
nginx.ingress.kubernetes.io/rewrite-target: /$1
nginx.ingress.kubernetes.io/use-regex: "true"
nginx.ingress.kubernetes.io/affinity: "cookie"
nginx.ingress.kubernetes.io/session-cookie-name: "PHPSESSID"
nginx.ingress.kubernetes.io/session-cookie-expires: "172800"
nginx.ingress.kubernetes.io/session-cookie-max-age: "172800"
另一个会有这个
nginx.ingress.kubernetes.io/backend-protocol: "FCGI"
nginx.ingress.kubernetes.io/fastcgi-index: "index.php"
nginx.ingress.kubernetes.io/fastcgi-params-configmap: "example-cm"
这些配置不兼容,我找不到按主机指定配置的方法。
我也明白不可能有 2 个 Ingress 服务外部 HTTP 请求。
那么我不理解/做错了什么?
解决方案
我也明白不可能有 2 个 Ingress 服务外部 HTTP 请求
我不确定你在哪里找到的,但你完全可以做到这一点。
您应该能够创建两个单独的入口对象,如下所示:
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: frontdoor-bar
namespace: myapps
annotations:
kubernetes.io/ingress.class: nginx
cert-manager.io/cluster-issuer: letsencrypt-prod
nginx.ingress.kubernetes.io/rewrite-target: /$1
nginx.ingress.kubernetes.io/use-regex: "true"
nginx.ingress.kubernetes.io/affinity: "cookie"
nginx.ingress.kubernetes.io/session-cookie-name: "PHPSESSID"
nginx.ingress.kubernetes.io/session-cookie-expires: "172800"
nginx.ingress.kubernetes.io/session-cookie-max-age: "172800"
spec:
type: LoadBalancer
tls:
- hosts:
- bar.foo.dev
secretName: tls-secret-bar
rules:
- host: bar.foo.dev
http:
paths:
- backend:
serviceName: barfoo
servicePort: 80
path: /(.*)
---
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: frontdoor-foo
namespace: myapps
annotations:
kubernetes.io/ingress.class: nginx
cert-manager.io/cluster-issuer: letsencrypt-prod
nginx.ingress.kubernetes.io/backend-protocol: "FCGI"
nginx.ingress.kubernetes.io/fastcgi-index: "index.php"
nginx.ingress.kubernetes.io/fastcgi-params-configmap: "example-cm"
spec:
type: LoadBalancer
tls:
- hosts:
- foo.bar.dev
secretName: tls-secret-foo
rules:
- host: foo.bar.dev
http:
paths:
- backend:
serviceName: foobar
servicePort: 9000
path: /(.*)
这是一个完全有效的入口配置,并且很可能是唯一可以解决您的问题的有效配置。
每个入口对象配置一个域。
推荐阅读
- html - 如何将 ng-model 变量值设置为 null?
- ember.js - Ember 简单身份验证设计身份验证器失败
- amazon-web-services - v4l2loopback 无法在 aws ubuntu 18.04 上加载模块
- powershell - 脚本运行后Powershell自我删除
- excel - 将文本框值放入变量
- python - 使用 python3.8 和 Ubuntu 20.04 设置 VTK
- c# - 有人在 Azure Web 应用程序中使用 SQL 依赖项有问题吗?
- windows - Windows - 构建 .obj 文件时“命令行太长”
- python - 使用来自其他列的两个计算值的最大值创建 Pandas 列
- docker - 我们如何在 Kubernetes 集群中获取 NodePort 服务的 NodePort 的 tcpdump?