使用ingress控制器暴露kubernetes部署(前端)



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

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控制器本身公开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/(.*)

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

您可以将前端和后端服务仅保留在集群IP级别的

相关内容

  • 没有找到相关文章

最新更新