使用入口控制器公开kubernetes部署(前端)
我正在Kubernetes上部署许多docker容器的微型服务和角度前端。我已经使用入口控制器公开了这些服务,使用入口控制器指定每个服务,并在后端指定路径使用入口控制器公开kubernetes部署(前端),kubernetes,load-balancing,kubernetes-ingress,azure-aks,Kubernetes,Load Balancing,Kubernetes Ingress,Azure Aks,我正在Kubernetes上部署许多docker容器的微型服务和角度前端。我已经使用入口控制器公开了这些服务,使用入口控制器指定每个服务,并在后端指定路径 apiVersion: extensions/v1beta1 kind: Ingress 对于我的前端,我使用loadbalancer类型创建了一个服务 apiVersion: v1 kind: Service metadata: annotations: service.beta.kubernetes.io/azure-loa
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地址吗
在不创建外部负载平衡器的情况下,如何使用ingress controller本身公开UI?试试这种方法-
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/(.*)
您可以使用上面定义的策略,其中可以直接将前端映射到/并使用重写目标将主机名/api之类的内容映射到后端服务
您只能将前端和后端服务保持在clusterIP级别