서비스 패브릭 서비스에 대한 배치 정책

배치 정책은 보다 덜 일반적인 일부 구체적인 시나리오에서 서비스 배치를 제어하는 데 사용할 수 있는 추가적인 규칙입니다. 이러한 시나리오의 몇 가지 예는 다음과 같습니다.

  • 온-프레미스 데이터 센터 또는 Azure 지역 간에 Service Fabric 클러스터의 지리적 거리가 확대되는 경우
  • 사용자 환경이 지정학적 또는 법적 통제 또는 정책적 경계를 적용해야 하는 여러 영역에 확대되는 경우
  • 먼 거리 또는 보다 느리거나 덜 안정적인 네트워크 링크의 사용으로 인해 통신 성능 또는 대기 시간을 고려해야 할 경우
  • 특정 워크로드를 다른 워크로드와 함께 배치하거나 고객과 가까이에 배치해야 할 수도 있습니다.
  • 단일 노드에 파티션의 여러 상태 비저장 인스턴스가 필요합니다.

이러한 요구 사항 대부분은 클러스터의 장애 도메인으로 표시되는 클러스터의 실제 레이아웃과 맞춰 조정합니다.

이러한 시나리오를 해결하는 데 도움이 되는 고급 배치 정책은 다음과 같습니다.

  1. 잘못된 도메인
  2. 필수 도메인
  3. 기본 설정 도메인
  4. 복제본 압축 불가
  5. 노드에서 여러 상태 비저장 인스턴스 허용

다음 컨트롤은 대부분 노드 속성 및 배치 제약 조건을 통해 구성할 수 있지만 일부는 더 복잡합니다. Service Fabric Cluster Resource Manager는 좀 더 간단하게 이러한 추가 배치 정책을 제공합니다. 배치 정책은 명명된 서비스 인스턴스를 기준으로 구성됩니다. 동적으로 업데이트할 수도 있습니다.

잘못된 도메인 지정

InvalidDomain 배치 정책을 사용하여 특정 장애 도메인이 특정 서비스에 유효하지 않다고 지정할 수 있습니다. 이 정책을 사용하면 예를 들어 지정학적 또는 회사 정책상의 이유로 특정 영역에서 특정 서비스가 실행되지 않도록 할 수 있습니다. 별도 정책을 통해 잘못된 여러 도메인을 지정할 수 있습니다.

잘못된 도메인 예제

코드:

ServicePlacementInvalidDomainPolicyDescription invalidDomain = new ServicePlacementInvalidDomainPolicyDescription();
invalidDomain.DomainName = "fd:/DCEast"; //regulations prohibit this workload here
serviceDescription.PlacementPolicies.Add(invalidDomain);

PowerShell:

New-ServiceFabricService -ApplicationName $applicationName -ServiceName $serviceName -ServiceTypeName $serviceTypeName –Stateful -MinReplicaSetSize 3 -TargetReplicaSetSize 3 -PartitionSchemeSingleton -PlacementPolicy @("InvalidDomain,fd:/DCEast”)

필수 도메인 지정

필수 도메인 배치 정책 서비스에서는 해당 서비스가 지정된 도메인에만 있어야 합니다. 별도 정책을 통해 여러 필수 도메인을 지정할 수 있습니다.

필수 도메인 예제

코드:

ServicePlacementRequiredDomainPolicyDescription requiredDomain = new ServicePlacementRequiredDomainPolicyDescription();
requiredDomain.DomainName = "fd:/DC01/RK03/BL2";
serviceDescription.PlacementPolicies.Add(requiredDomain);

PowerShell:

New-ServiceFabricService -ApplicationName $applicationName -ServiceName $serviceName -ServiceTypeName $serviceTypeName –Stateful -MinReplicaSetSize 3 -TargetReplicaSetSize 3 -PartitionSchemeSingleton -PlacementPolicy @("RequiredDomain,fd:/DC01/RK03/BL2")

상태 저장 서비스의 주 복제본에 대한 기본 설정 도메인 지정

기본 설정 주 도메인은 주 복제본이 될 장애 도메인을 지정합니다. 정상 상태인 경우 주 복제본은 이 도메인에 위치하게 됩니다. 도메인 또는 주 복제본에 오류가 발생하거나 종료되면 주 복제본은 일부 다른 위치(이상적으로는 동일한 도메인)로 이동됩니다. 새 위치가 기본 설정 도메인이 아닌 경우 Cluster Resource Manager는 새 위치를 가능한 한 빨리 기본 도메인으로 이동시킵니다. 이 정책은 Azure 지역 또는 여러 데이터 센터 간에 걸쳐 있는 클러스터에서 가장 유용합니다. 이 정책은 Azure 지역 또는 여러 데이터 센터에 걸쳐 있으나 특정 위치에 배치되는 것을 선호하는 서비스를 포함하는 클러스터에서 가장 유용합니다. 주 복제본을 해당 사용자 또는 기타 서비스에 가깝게 배치하면 기본적으로 주 복제본이 처리하는 읽기 작업에서 특히 대기 시간을 낮추는 데 도움이 됩니다.

기본 설정 주 도메인 및 장애 조치(failover)

ServicePlacementPreferPrimaryDomainPolicyDescription primaryDomain = new ServicePlacementPreferPrimaryDomainPolicyDescription();
primaryDomain.DomainName = "fd:/EastUS/";
serviceDescription.PlacementPolicies.Add(primaryDomain);

PowerShell:

New-ServiceFabricService -ApplicationName $applicationName -ServiceName $serviceName -ServiceTypeName $serviceTypeName –Stateful -MinReplicaSetSize 3 -TargetReplicaSetSize 3 -PartitionSchemeSingleton -PlacementPolicy @("PreferredPrimaryDomain,fd:/EastUS")

복제본 배포 요구 및 압축 허용 안 함

복제본은 일반적으로 클러스터가 정상 상태일 때 장애 및 업그레이드 도메인에 걸쳐 분산됩니다. 그러나 특정 파티션에 대해 둘 이상의 복제본이 단일 도메인으로 압축될 수 있는 경우가 있습니다. 예를 들어, 클러스터에 3개의 장애 도메인(fd:/0, fd:/1 및 fd:/2)에 있는 9개의 노드가 있고 서비스에 3개의 복제본이 있다고 가정하겠습니다. fd:/1 및 fd:/2의 해당 복제본에 사용되는 노드가 중단되었다고 가정하겠습니다. 일반적으로 Cluster Resource Manager는 이러한 동일한 장애 도메인에서 다른 노드를 기본으로 사용합니다. 이 경우에 용량 문제로 인해 해당 도메인의 다른 노드가 유효하지 않다고 가정하겠습니다. Cluster Resource Manager가 해당 복제본에 대한 대체 항목을 빌드하는 경우 fd:/0에서 노드를 선택해야 합니다. 그러나 해당 작업을 수행하면 장애 도메인 제약을 위반하는 상황이 발생합니다. 복제본을 압축하면 전체 복제본 세트가 가동 중단되거나 손실될 가능성도 높아집니다.

참고 항목

제약 조건 및 제약 조건 우선 순위에 대한 자세한 내용은 이 항목을 확인하세요.

The Load Balancer has detected a Constraint Violation for this Replica:fabric:/<some service name> Secondary Partition <some partition ID> is violating the Constraint: FaultDomain와 같은 상태 메시지가 표시된 경우 이 조건 또는 비슷한 조건에 도달한 것입니다. 일반적으로 한 개나 두 개의 복제본만 일시적으로 함께 압축됩니다. 지정된 도메인에 쿼럼 미만의 복제본이 있는 경우 안전합니다. 압축은 드물지만 발생할 수 있습니다. 그리고 노드가 다시 돌아오기 때문에 일반적으로 이러한 상황은 일시적입니다. 노드가 중단되고 Cluster Resource Manager가 대체 노드를 빌드해야 하는 경우 일반적으로 이상적인 장애 도메인에서 사용할 수 있는 다른 노드가 있습니다.

일부 워크로드는 더 적은 도메인에 압축되는 경우에도 항상 목표 복제본 수가 있습니다. 이러한 워크로드는 동시에 발생하는 영구적인 도메인 오류 전체에 대해 안정적이며 일반적으로 로컬 상태를 복구할 수 있습니다. 다른 워크로드는 위험 정확성 또는 데이터의 손실이 발생하기 전에 가동 중지 시간을 감수합니다. 대부분의 프로덕션 워크로드가 세 개 이상의 복제본, 세 개 이상의 장애 도메인 및 장애 도메인당 여러 개의 유효한 노드에서 실행됩니다. 따라서 기본 동작은 기본적으로 도메인 압축을 허용합니다. 기본 동작은 일시적인 도메인 압축을 의미하더라도 정상적인 부하 분산 및 장애 조치(failover)를 통해 이러한 극단적인 경우를 처리하도록 합니다.

지정된 워크로드에 대해 이러한 압축을 사용하지 않도록 설정하려면 서비스에서 RequireDomainDistribution 정책을 지정할 수 있습니다. 이 정책을 설정하면 Cluster Resource Manager를 통해 동일한 장애 도메인 또는 업그레이드 도메인에서 동일한 파티션의 두 복제본이 실행되지 않도록 합니다.

코드:

ServicePlacementRequireDomainDistributionPolicyDescription distributeDomain = new ServicePlacementRequireDomainDistributionPolicyDescription();
serviceDescription.PlacementPolicies.Add(distributeDomain);

PowerShell:

New-ServiceFabricService -ApplicationName $applicationName -ServiceName $serviceName -ServiceTypeName $serviceTypeName –Stateful -MinReplicaSetSize 3 -TargetReplicaSetSize 3 -PartitionSchemeSingleton -PlacementPolicy @("RequiredDomainDistribution")

현재 지리적으로 분산되지 않은 클러스터의 서비스에 대해 이러한 구성을 사용할 수 있나요? 가능하지만 그럴 필요는 없습니다. 시나리오에서 꼭 필요한 경우가 아니면 유효하지 않은 필수 기본 도메인 구성은 피해야 합니다. 지정된 워크로드를 단일 랙에서 실행하거나 다른 로컬 클러스터의 일부 세그먼트를 기본으로 사용하려는 것은 바람직하지 않습니다. 여러 하드웨어 구성을 장애 도메인 간에 분산하고 일반 배치 제약 조건 및 노드 속성을 통해 처리해야 합니다.

단일 노드에 파티션의 여러 상태 비저장 인스턴스 배치

AllowMultipleStatelessInstancesOnNode 배치 정책을 사용하면 단일 노드에 파티션의 여러 상태 비저장 인스턴스를 배치할 수 있습니다. 기본적으로 노드에 단일 파티션의 여러 인스턴스를 배치할 수 없습니다. -1 서비스를 사용하는 경우에도 지정된 명명된 서비스에 대해 클러스터의 노드 수를 초과하여 인스턴스 수를 스케일링할 수 없습니다. 이 배치 정책은 이 제한을 없애고 InstanceCount를 노드 수보다 높게 지정할 수 있도록 허용합니다.

The Load Balancer has detected a Constraint Violation for this Replica:fabric:/<some service name> Secondary Partition <some partition ID> is violating the Constraint: ReplicaExclusion와 같은 상태 메시지가 표시된 경우 이 조건 또는 비슷한 조건에 도달한 것입니다.

서비스에 이 배치 정책을 적용하도록 옵트인하려면 다음 구성을 사용하도록 설정합니다.

<Section Name="Common">
  <Parameter Name="AllowCreateUpdateMultiInstancePerNodeServices" Value="True" />
  <Parameter Name="HostReuseModeForExclusiveStateless" Value="1" />
</Section>

서비스에 AllowMultipleStatelessInstancesOnNode 정책을 지정하면 InstanceCount를 클러스터의의 노드 수보다 높게 설정할 수 있습니다.

코드:

ServicePlacementAllowMultipleStatelessInstancesOnNodePolicyDescription allowMultipleInstances = new ServicePlacementAllowMultipleStatelessInstancesOnNodePolicyDescription();
serviceDescription.PlacementPolicies.Add(allowMultipleInstances);

PowerShell:

New-ServiceFabricService -ApplicationName $applicationName -ServiceName $serviceName -ServiceTypeName $serviceTypeName -Stateless –PartitionSchemeSingleton –PlacementPolicy @(“AllowMultipleStatelessInstancesOnNode”) -InstanceCount 10 -ServicePackageActivationMode ExclusiveProcess 

참고 항목

현재 이 정책은 ExclusiveProcess 서비스 패키지 활성화 모드의 상태 비저장 서비스에 대해서만 지원됩니다.

Warning

정적 포트 엔드포인트와 함께 사용하는 경우 정책이 지원되지 않습니다. 두 인스턴스를 함께 사용하면 같은 노드의 여러 인스턴스가 같은 포트에 바인딩하려고 하며 시작될 수 없으므로 비정상 클러스터가 발생할 수 있습니다.

참고 항목

이 배치 정책과 함께 높은 MinInstanceCount 값을 사용하면 애플리케이션 업그레이드가 중단될 수 있습니다. 예를 들어 5노드 클러스터가 있고 InstanceCount=10으로 설정하는 경우 각 노드에 두 개의 인스턴스가 있습니다. MinInstanceCount=9로 설정한 경우 앱 업그레이드를 시도하면 중단될 수 있습니다. MinInstanceCount=8로 설정하면 중단을 방지할 수 있습니다.

다음 단계