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