防火墙后的 Azure Service Fabric 集群

一则或许对你有用的小广告

欢迎加入小哈的星球 ,你将获得:专属的项目实战 / Java 学习路线 / 一对一提问 / 学习打卡/ 赠书活动

目前,正在 星球 内带小伙伴们做第一个项目:全栈前后端分离博客项目,采用技术栈 Spring Boot + Mybatis Plus + Vue 3.x + Vite 4手把手,前端 + 后端全栈开发,从 0 到 1 讲解每个功能点开发步骤,1v1 答疑,陪伴式直到项目上线,目前已更新了 204 小节,累计 32w+ 字,讲解图:1416 张,还在持续爆肝中,后续还会上新更多项目,目标是将 Java 领域典型的项目都整上,如秒杀系统、在线商城、IM 即时通讯、权限管理等等,已有 870+ 小伙伴加入,欢迎点击围观

在 Azure 上为 Internet 托管客户端托管 Service Fabric 集群需要将其部署在具有公共 IP 的负载均衡器后面。默认情况下,服务不会配置任何网络侦听器;因此,每个服务都需要通过覆盖 StatefulServiceBase 和 StatelessServiceBase 类中定义的 CreateCommunicationListener() 来实现自己的侦听器;签名如下所示:


 protected override ICommunicationListener CreateCommunicationListener() { ... }

有关实施您自己的通信堆栈的指南,请参阅 服务通信模型

WcfCommunicationListner 由 Service Fabric SDK 提供,用于在有状态和无状态服务中托管 WCF 终结点。侦听器的用法记录在 WCF Communication Listener 中。

WcfCommunicationListener 的当前实现不知道公共 IP 地址/FQDN;因此,对于 NetTcpBinding,它会生成以下具有私有 IP 地址的通信端点:


 protected override ICommunicationListener CreateCommunicationListener() { ... }

如果客户端也位于同一网络中,这将正常工作;但是,对于基于 Internet 的访问,必须将本地 IP 地址替换为负载均衡器的公共 IP/FQDN。

为解决此问题,我使用了以下扩展 WcfCommunicationListener 的侦听器实现:


 protected override ICommunicationListener CreateCommunicationListener() { ... }

Initialize() 期望通过 Config 包定义网关的 FQDN,如以下 Settings.xml 片段所示: <!-- Settings.xml 位于服务项目的 Config 目录中 -->


 protected override ICommunicationListener CreateCommunicationListener() { ... }

OpenAsync() 只是将主机 IP 地址替换为负载均衡器的 FQDN。