使用入口控制器公开 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 级别保留前端和后端服务
我正在 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 级别保留前端和后端服务