是否可以动态添加主机以使用 Kubernetes 进入入口?
Is it possible to dynamically add hosts to ingress with Kubernetes?
如果您正在管理入口服务,例如下面的示例,而不是更新下面的入口文件,有没有办法添加额外的 host/service 例如 echo3.example.com 而不需要应用原始文件的更新版本?
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: echo-ingress
spec:
rules:
- host: echo1.example.com
http:
paths:
- backend:
serviceName: echo1
servicePort: 80
- host: echo2.example.com
http:
paths:
- backend:
serviceName: echo2
servicePort: 80
# NEW HOST/SERVICE
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: echo-ingress
spec:
rules:
- host: echo3.example.com ### <= `echo3` addeded
http:
paths:
- backend:
serviceName: echo3
servicePort: 80
有没有办法在不需要扩展旧文件的情况下应用这个新主机?
我的意思是您可以将其设为单独的 Ingress object/file,无需将其放在同一个 Ingress 中。或者您可以使用 Kustomize 之类的东西。
如果您应用这两个文件,第二个文件将覆盖第一个文件,因为它们具有相同的名称。因此,每次添加新规则时都需要编辑原始文件。
避免此问题的一种可能解决方案是使用 Contour。在那种情况下,您可以将每个 IngressRoute
保存在一个单独的资源中,避免这样的冲突。
在你的情况下,你会得到类似的东西:
# ingressroute-echo1.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-1
spec:
virtualhost:
fqdn: echo1.example.com
routes:
- match: /
services:
- name: echo1
port: 80
# ingressroute-echo2.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-2
spec:
virtualhost:
fqdn: echo2.example.com
routes:
- match: /
services:
- name: echo2
port: 80
# ingressroute-echo3.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-3
spec:
virtualhost:
fqdn: echo3.example.com
routes:
- match: /
services:
- name: echo3
port: 80
您可以将具有不同注释的不同入口对象 also.Make 到主机和服务的两个入口文件。
如果您正在管理入口服务,例如下面的示例,而不是更新下面的入口文件,有没有办法添加额外的 host/service 例如 echo3.example.com 而不需要应用原始文件的更新版本?
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: echo-ingress
spec:
rules:
- host: echo1.example.com
http:
paths:
- backend:
serviceName: echo1
servicePort: 80
- host: echo2.example.com
http:
paths:
- backend:
serviceName: echo2
servicePort: 80
# NEW HOST/SERVICE
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: echo-ingress
spec:
rules:
- host: echo3.example.com ### <= `echo3` addeded
http:
paths:
- backend:
serviceName: echo3
servicePort: 80
有没有办法在不需要扩展旧文件的情况下应用这个新主机?
我的意思是您可以将其设为单独的 Ingress object/file,无需将其放在同一个 Ingress 中。或者您可以使用 Kustomize 之类的东西。
如果您应用这两个文件,第二个文件将覆盖第一个文件,因为它们具有相同的名称。因此,每次添加新规则时都需要编辑原始文件。
避免此问题的一种可能解决方案是使用 Contour。在那种情况下,您可以将每个 IngressRoute
保存在一个单独的资源中,避免这样的冲突。
在你的情况下,你会得到类似的东西:
# ingressroute-echo1.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-1
spec:
virtualhost:
fqdn: echo1.example.com
routes:
- match: /
services:
- name: echo1
port: 80
# ingressroute-echo2.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-2
spec:
virtualhost:
fqdn: echo2.example.com
routes:
- match: /
services:
- name: echo2
port: 80
# ingressroute-echo3.yaml
apiVersion: contour.heptio.com/v1beta1
kind: IngressRoute
metadata:
name: echo-ingress-3
spec:
virtualhost:
fqdn: echo3.example.com
routes:
- match: /
services:
- name: echo3
port: 80
您可以将具有不同注释的不同入口对象 also.Make 到主机和服务的两个入口文件。