如何获取Service Fabric微服务的实例数?

时间:2018-11-27 13:11:56

标签: c# .net azure microservices azure-service-fabric

我有服务。它向第三方API发出请求。由于该API设置了每秒的请求数量,因此我需要为我的请求设置限制。

<DefaultServices>
    <Service Name="MyService">
      <StatelessService ServiceTypeName="MyService" InstanceCount="-1">
        <UniformInt64Partition PartitionCount="5" LowKey="0" HighKey="5" />
      </StatelessService>
    </Service>
  </DefaultServices>

我有此配置。 “ -1”表示我没记错的最大可用金额。

如何获取“ MyService”实例的数量?我还应该计算分区数量以获得实际数量吗?

2 个答案:

答案 0 :(得分:1)

简单来说,就是将分区数乘以服务具有的已分配副本(有状态)或实例(无状态)的数量:

在您的情况下,您将实例计数设置为-1,假设节点数为3,则数学公式为:

3(instances) * 5(partitions) = 15 (instances)

使用PowerShell

$instances =  0
foreach ($partition in Get-ServiceFabricPartition -ServiceName "fabric:/AppName/ServiceName") {
   foreach ($replica in Get-ServiceFabricReplica -PartitionId $partition.PartitionId) 
   {
        if($replica.ReplicaStatus -eq 'Ready'){
            $instances++ 
        }
   }
}
echo $instances

使用FabricClient:

int instances = 0;
var fabricClient = new FabricClient();
var partitions = await fabricClient.QueryManager.GetPartitionListAsync(new Uri("fabric:/AppName/ServiceName"));
foreach (var partition in partitions)
{
    instances += (await fabricClient.QueryManager.GetReplicaListAsync(partition.PartitionInformation.Id)).Where(r => r.ReplicaStatus == ServiceReplicaStatus.Ready).Count();
}

以上脚本应适用于有状态和无状态

有一些警告:

  • 有状态服务具有主服务和辅助服务的概念,如果不处理辅助服务中的请求,则应仅考虑分区数(与主副本的数目相同)
  • 当设置为-1时,不要以节点数为实例数,仅当该节点可用于该副本时,SF才会将服务放置在该节点中,这意味着:
    • 如果未禁用该节点,则不会在禁用的节点上分配副本\实例
    • 如果该节点没有副本空间
    • 如果服务有展示位置限制
    • 如果服务在节点中被列出为阻止
  • 基于上述规则,也不要考虑InstanceCount,因为SF可能无法放置请求的副本数。并且当InstanceCount为-1​​时,您必须迭代所有副本\ instances。
  • 如上所述,仅考虑处于就绪状态的副本。我没有考虑处于其他状态(例如“正在构建”,“正在删除”等)的实例。

答案 1 :(得分:0)

InstanceCount为-1​​表示服务实例正在群集中的每个节点上运行。因此,一个5节点群集将运行5个MyService实例,每个节点上一个实例。无状态服务没有分区(嗯,SingletonPartition只有一个分区)

因此,获取实例数只需查看InstanceCount的值即可。如果它是<> -1,则它是节点数,否则,它是实例数。

如果您希望通过编程方式尝试使用FabricClient类:

var fabricClient = new FabricClient();
var partitions = await fabricClient.QueryManager.GetPartitionListAsync(new Uri("fabric:/Application2/Stateless1"));
var singletonPartition = (StatelessServicePartition)partitions.First(); // stateless service has just one partition
Console.WriteLine(singletonPartition.InstanceCount);