gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 05:47:17 26 4
gpt4 key购买 nike

假设我有一个包含 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com