【问题标题】:Expose a kubernetes deployment (frontend) using ingress controller使用入口控制器公开 kubernetes 部署(前端)
【发布时间】:2019-10-29 08:52:57
【问题描述】:

我正在 Kubernetes 上部署一些微服务和 Angular 前端的 docker 容器。我已经使用入口控制器公开了服务,并使用它指定每个服务,并在后端指定路径。

apiVersion: extensions/v1beta1
kind: Ingress

对于我的前端,我创建了一个负载均衡器类型的服务。

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/azure-load-balancer-resource-group: my-resource-group
  name: myapp-svc
  namespace: ui
spec:
  loadBalancerIP: SOME_IP_ADDRESS
  type: LoadBalancer
  ports:
  - port: 80
 selector:
   app: myapp

这工作正常,但现在我有两个 IP 地址,一个用于 UI 负载平衡器,另一个用于入口控制器(用于 API)。

我可以只使用一个 IP 地址吗?

如何在不创建外部负载平衡器的情况下使用入口控制器本身公开 UI?

【问题讨论】:

    标签: kubernetes load-balancing kubernetes-ingress azure-aks


    【解决方案1】:

    试试这个方法-

    apiVersion: extensions/v1beta1
    kind: Ingress
    metadata:
      annotations:
        kubernetes.io/ingress.class: nginx
        nginx.ingress.kubernetes.io/rewrite-target: /$1
        nginx.ingress.kubernetes.io/service-upstream: "true"
      name: rule-name
      namespace: default
    spec:
      rules:
      - host: hostname
        http:
          paths:
          - backend:
              serviceName: frontend-service
              servicePort: port-number
            path: /(.*)
          - backend:
              serviceName: backend-service
              servicePort: port-number
            path: /api/(.*)
    

    您可以使用上面定义的策略,您可以直接将前端映射到 / 并使用 rewrite-target 将主机名/api 之类的任何内容映射到后端服务。

    您只能将前端和后端服务保持在 clusterIP 级别

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2019-05-06
      • 1970-01-01
      • 1970-01-01
      • 2021-01-28
      • 1970-01-01
      • 2020-07-06
      • 2021-09-20
      相关资源
      最近更新 更多