【问题标题】:Linking a website or domain with AKS cluster将网站或域与 AKS 群集链接
【发布时间】:2021-05-11 06:45:08
【问题描述】:

在 Azure Kubernetes 中,服务或负载均衡器会公开 IP 地址以访问容器的应用程序。如果其中一个容器具有 Web 应用程序,那么它将作为 IP 对外公开,​​例如 115.111.0.145。假设我有一个从 GoDaddy 购买的网站www.example.com,那么如何将此域与 AKS 集群链接,以便最终用户通过名称而不是 IP 访问该网站?

【问题讨论】:

    标签: kubernetes azure-aks


    【解决方案1】:

    您可以使用 Ingress。 Ingress 是一个 API 对象,用于管理对集群中服务的外部访问,通常是 HTTP。 Ingress 可以配置为提供服务外部可访问的 URL、负载平衡流量、终止 SSL/TLS 并提供基于名称的虚拟主机。更多详情可以查看官方kubernetesIngress-doc

    这里给出了一个简单的入口 yaml 清单:

    apiVersion: networking.k8s.io/v1
    kind: Ingress
    metadata:
      name: simple-fanout-example
    spec:
      rules:
      - host: foo.bar.com
        http:
          paths:
          - path: /foo
            pathType: Prefix
            backend:
              service:
                name: service1
                port:
                  number: 4200
          - path: /bar
            pathType: Prefix
            backend:
              service:
                name: service2
                port:
                  number: 8080
    

    【讨论】:

    • 请注意,您仍需要更新 DNS 记录以指向入口控制器外部 IP。
    • 我同意 Sahadat Hossain 的观点,创建 Ingress 是一个好方法。对于Azure AKS的详细说明可以在这里找到:create-an-ingress-controller
    • 感谢@Sahadat 帮助我。
    【解决方案2】:

    在这种情况下,您可以使用 Microsoft azure 的 DNS 区域服务,并可以为您的站点定义一组规范名称,例如 -

    1. example.com 可以标记为“A”类型记录,即向负载均衡器公开的 Nginx 控制器服务的 IP。

    2. 然后您可以创建多个规范名称,例如 - api.example.com 并且可以将其映射到 example.com 作为 DNS 区域中的 CNAME 类型记录。

    这有助于您将来自多个域的流量引导到集群。

    kubectl get svc 会为你提供 nginx 服务的外部 IP,你可以在 DNS 区域的 A 记录中提供该外部 IP。

    希望对你有帮助!!

    【讨论】:

    • 感谢@Tushar 的指导。
    猜你喜欢
    • 1970-01-01
    • 2021-03-21
    • 2022-11-01
    • 2018-08-01
    • 2018-09-07
    • 1970-01-01
    • 2018-04-22
    • 2011-10-07
    • 1970-01-01
    相关资源
    最近更新 更多