是否可以使用 Kubernetes 动态添加主机到入口?

den*_*ski 6 kubernetes kubernetes-ingress

如果您正在管理入口服务(如下例所示),是否可以添加其他主机/服务(例如 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

Run Code Online (Sandbox Code Playgroud)
# 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
Run Code Online (Sandbox Code Playgroud)

有没有一种方法可以应用这个新主机而不需要扩展旧文件?

Ped*_*iro 2

如果应用这两个文件,第二个文件将覆盖第一个文件,因为它们具有相同的名称。因此,每次添加新规则时都需要编辑原始规则。

避免此问题的一种可能的解决方案是使用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
Run Code Online (Sandbox Code Playgroud)