azure - 如何查找 Service Fabric 群集上的特定节点

标签 azure azure-service-fabric

假设我有一个包含 5 个节点的 Service Fabric 群集。在其中一个节点上,我运行一项名为 Cache 的服务:

<Service Name="Cache" ServicePackageActivationMode="ExclusiveProcess">
  <StatelessService ServiceTypeName="CacheType" InstanceCount="1">
    <SingletonPartition />
  </StatelessService>
</Service>

CacheType 是一些 Docker 容器,它公开端口 8080 并为我的应用程序提供一些内部服务。在这种情况下,我只需要其中一个,因此我将 InstanceCount 设置为 1。当我将应用程序部署到集群时,App Fabric 将选择一个节点来安装“缓存”。我的问题是我的应用程序如何找出哪个节点以便它可以连接到它?

我确实发现有一个Hostname <ContainerHostPolicies> 上的属性节点,所以我可以做这样的事情:

<ContainerHostPolicies CodePackageRef="Code" Hostname="Cache">

现在,从 Docker 容器中我可以 PING Cache并连接到运行我的服务的容器。这很棒,但是当我碰巧在同一个节点上时才有效。如果我在节点 1 上并且我的缓存服务在节点 3 上运行,则这不起作用。

有一个例子 here ,这是一个投票亭应用程序,它可以满足我的需求。他们所做的是设置一个单独的负载均衡器池,将一些公共(public) IP 地址映射到投票服务的后端池。然后,应用程序可以连接到该单个公共(public) IP 地址。然而,就我而言,我需要这是一个完全内部的事情,我的缓存服务在集群虚拟网络之外的任何地方都无法访问。我还宁愿避免负载均衡器的开销。

另一个想法是使用某种放置约束来表示“嘿,我只想将此服务安装在具有此 DNS 名称的节点上”或其他内容,但这看起来相当老套。有推荐的方法吗?

最佳答案

您可以为服务设置 DNS 名称。

这是来自 docs 的示例:

ApplicationManifest.xml中。

<Service Name="Stateless1" ServiceDnsName="service1.application1">
  <StatelessService ServiceTypeName="Stateless1Type" InstanceCount="[Stateless1_InstanceCount]">
    <SingletonPartition />
  </StatelessService>
</Service>

如果您的服务使用分区架构,那么您应该遵循this确保正确解决这些问题的指南。

关于azure - 如何查找 Service Fabric 群集上的特定节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52668744/

相关文章:

azure - 可靠的 Actor : Console application: Application Ready message never appearing

Azure IoT 中心证书

asp.net - 指定用于持续部署到 Azure Web 应用程序的配置转换

angularjs - Angular 的 $cookies 仅适用于 'localhost'

.net-core - 意外降级? Nuget 包管理器不显示 Microsoft.ServiceFabric.Services.Remoting 的最新版本

c# - 在 Service Fabric 服务中使用 HttpClient.GetAsync 会引发 "unable to connect to remote service"异常

c# - 如何通过选项配置设置自定义私有(private)DbContext包中的Azure默认TenantId

Azure 认知服务 : Where are the missing Custom Vision Performance Statistics?

azure - 在 Service Fabric 中,我可以使用应用程序参数更改 ServiceManifest.xml 文件中的参数吗?

c# - 控制台应用程序客户端到 Service Fabric 无状态服务