gpt4 book ai didi

ssl - 哪个 Kubernetes 入口 "wins"(同一主机的 tls 和多个入口)?

转载 作者:行者123 更新时间:2023-12-02 11:46:40 25 4
gpt4 key购买 nike

假设我有两个入口 ingress-aingress-b 用于同一主机但路径不同:

入口:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
annotations:
kubernetes.io/ingress.class: nginx
name: app-a
namespace: namespace-a
spec:
rules:
- host: myhost.com
http:
paths:
- backend:
serviceName: app-a
servicePort: 8080
path: /path-a
tls:
- hosts:
- myhost.com
secretName: tls-a

入口-b:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
annotations:
kubernetes.io/ingress.class: nginx
name: app-b
namespace: namespace-b
spec:
rules:
- host: myhost.com
http:
paths:
- backend:
serviceName: app-b
servicePort: 8080
path: /path-b
tls:
- hosts:
- myhost.com
secretName: tls-b

现在我需要更新证书。假设我在 tls-new 中创建了新的 secret ,但只更新了 ingress-a 以指向它。这两个入口中的哪一个会胜出

我想我应该简单地覆盖现有的 secret ,但我试图了解入口规则在上述场景中如何工作,其中为同一主机引用了两个不同的 tls secret 。

最佳答案

NGINX 和 NGINX Plus Ingress controller for Kubernetes 支持可合并的入口类型。

Master 是使用 nginx.org/mergeable-ingress-type: master 声明的。 Master 将处理主机级别的所有配置,包括 TLS 配置,以及将应用于完整主机的任何注释。在包含主值的唯一主机上只能有一个入口资源。路径不能是入口资源的一部分。

Minion 是使用 nginx.org/mergeable-ingress-type: minion 声明的。 Minion 将用于将不同的位置附加到具有 Master 值的入口资源。不允许 TLS 配置。只要它们没有冲突路径,就可以为每个 master 应用多个 minions。如果存在冲突路径,则将使用在最旧的 minion 上定义的路径。

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: cafe-ingress-master
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.org/mergeable-ingress-type: "master"
spec:
tls:
- hosts:
- cafe.example.com
secretName: cafe-secret
rules:
- host: cafe.example.com

---

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: cafe-ingress-coffee-minion
annotations:
kubernetes.io/ingress.class: "nginx"
nginx.org/mergeable-ingress-type: "minion"
spec:
rules:
- host: cafe.example.com
http:
paths:
- path: /coffee
backend:
serviceName: coffee-svc
servicePort: 80

minion 不能有 TLS,只有 master 可以有 TLS,你在 master 中更改 TLS。

关于ssl - 哪个 Kubernetes 入口 "wins"(同一主机的 tls 和多个入口)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60851669/

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