我正在为 Google Cloud 实例中的 Web 应用程序设置一个裸机式 kubernetes 集群,我正在通过入口控制器连接到微服务。如何从所有传入主机访问入口控制器?
有一个 pod 运行 angular Web 应用程序,另一个 pod 运行节点 api 微服务。Angular Web Application 已在全球范围内公开。当从外部访问微服务并使用主机名传递标头时,我能够获得预期的响应。在删除入口 yaml 中的主机时,我无法访问入口。
kind: Ingress
metadata:
annotations:
ingress.kubernetes.io/rewrite-target: nginx
creationTimestamp: "2019-08-12T07:41:37Z"
generation: 7
name: test
namespace: default
resourceVersion: "546400"
selfLink: /apis/extensions/v1beta1/namespaces/default/ingresses/test
uid: 374836d2-34c3-4053-b0e3-9fe3f63167cc
spec:
rules:
- host: bar.com
http:
paths:
- backend:
serviceName: login-service
servicePort: 3000
path: /login-service
- backend:
serviceName: organization-service
servicePort: 3000
path: /organization-service
status:
loadBalancer:
ingress:
- ip: 10.128.0.16
- ip: 203.0.113.2
除了要从入口中的指定主机(bar.com)以外的所有主机访问的入口。
从外部集群(全局)访问 API 微服务还有其他方法吗?
为了从集群外部访问 API 服务(全局)。
创建一个代理nginx服务器并公开nginx代理服务器的端口。从 Web 应用程序服务器,通过外部 IP 和公开的端口调用对代理服务器的请求。代理服务器会将请求传递给受尊重的 API 微服务,并返回预期的响应。
编辑 nginx.conf 文件。
location /<your_requested_URL> {
proxy_pass http://service_name:port;
}