AKS K8S - 使用服务名称从 angular 前端访问 spring-boot 应用程序
AKS K8S - access spring-boot app from angular frontend using service name
我有两个使用 angular 开发的应用程序前端和使用 spring-boot 开发的后端。这两个应用程序 运行 在同一个命名空间中。
已经创建了两个类型的服务:Loadbalancer。
- 前端说
frontend-app-lb
(暴露9001)
- 后端说
backend-app-lb
(暴露9000)。
我能够通过外部 IP 获得响应。使用 curl http://<External-ip>:900[0/1]/
在angular应用程序中,我配置了环境-prod.ts,baseurl为http://<External-ip-of-backend-app-lb>:9000/
。在允许 CORS 的情况下,能够访问后端应用程序。
我也知道,如果应用程序 运行 在不同的命名空间中,我们可以使用此 http://<service-name>.<namespace>.svc.cluster.local:port
.
从不同的命名空间访问 application/pod
如何仅使用 baseurl 中的服务名称访问同一命名空间中的后端应用程序 运行,如 http://backend-app-lb:9000
。 - 这可能吗?
我发现,访问 http://backend-app-lb:9000
可能不是一种方法。
其他方法:
方法 #1:使用 Azure 应用程序网关:
将后端服务公开为 LoadBalancer 类型的服务(在我的例子中是部署在 AKS 中的应用程序)。因此配置了应用程序网关(第 7 层)。
- 说任何 url
/backend-api
连接到后端应用程序。
在前端应用程序 environment.prod.ts
中,使用 /backend-api
作为基础 url 连接到后端 api.
方法 #2:使用 Nginx 代理
- 如果前端应用程序是在 Ngnix 服务器上开发的,使用我们创建代理并访问后端服务的配置。
- 参考资料可在 Kubernetes documentation
- 在这种情况下,后端应用程序可以作为服务公开(它可以是 NodePort 或 LoadBalancer 类型)。
这两种方法在某种程度上使前端应用程序对后端服务的访问变得简单,并且无需在构建期间进行操作。
我有两个使用 angular 开发的应用程序前端和使用 spring-boot 开发的后端。这两个应用程序 运行 在同一个命名空间中。
已经创建了两个类型的服务:Loadbalancer。
- 前端说
frontend-app-lb
(暴露9001) - 后端说
backend-app-lb
(暴露9000)。
我能够通过外部 IP 获得响应。使用 curl http://<External-ip>:900[0/1]/
在angular应用程序中,我配置了环境-prod.ts,baseurl为http://<External-ip-of-backend-app-lb>:9000/
。在允许 CORS 的情况下,能够访问后端应用程序。
我也知道,如果应用程序 运行 在不同的命名空间中,我们可以使用此 http://<service-name>.<namespace>.svc.cluster.local:port
.
如何仅使用 baseurl 中的服务名称访问同一命名空间中的后端应用程序 运行,如 http://backend-app-lb:9000
。 - 这可能吗?
我发现,访问 http://backend-app-lb:9000
可能不是一种方法。
其他方法:
方法 #1:使用 Azure 应用程序网关:
将后端服务公开为 LoadBalancer 类型的服务(在我的例子中是部署在 AKS 中的应用程序)。因此配置了应用程序网关(第 7 层)。
- 说任何 url
/backend-api
连接到后端应用程序。
- 说任何 url
在前端应用程序
environment.prod.ts
中,使用/backend-api
作为基础 url 连接到后端 api.
方法 #2:使用 Nginx 代理
- 如果前端应用程序是在 Ngnix 服务器上开发的,使用我们创建代理并访问后端服务的配置。
- 参考资料可在 Kubernetes documentation
- 在这种情况下,后端应用程序可以作为服务公开(它可以是 NodePort 或 LoadBalancer 类型)。
这两种方法在某种程度上使前端应用程序对后端服务的访问变得简单,并且无需在构建期间进行操作。