防火墙后的 Azure Service Fabric 集群

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

欢迎加入小哈的星球 ,你将获得:专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...点击查看项目介绍 ;
  • 《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接: http://116.62.199.48/ ;

截止目前, 星球 内专栏累计输出 63w+ 字,讲解图 2808+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,权限管理,Spring Cloud Alibaba 微服务等等,已有 2200+ 小伙伴加入学习 ,欢迎点击围观

在 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。

相关文章