使用入口控制器公开 kubernetes 部署(前端)

Expose a kubernetes deployment (frontend) using ingress controller

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

apiVersion: extensions/v1beta1
kind: Ingress

对于我的前端,我创建了一个类型为 loadbalancer 的服务。

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?

试试这个方法-

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  annotations:
    kubernetes.io/ingress.class: nginx
    nginx.ingress.kubernetes.io/rewrite-target: /
    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 将 hostname/api 之类的任何内容映射到后端服务。

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