Class ScalingPolicy
- All Implemented Interfaces:
Serializable,SdkPojo,ToCopyableBuilder<ScalingPolicy.Builder,ScalingPolicy>
Rule that controls how a fleet is scaled. Scaling policies are uniquely identified by the combination of name and fleet ID.
- See Also:
-
Nested Class Summary
Nested Classes -
Method Summary
Modifier and TypeMethodDescriptionstatic ScalingPolicy.Builderbuilder()final ComparisonOperatorTypeComparison operator to use when measuring a metric against the threshold value.final StringComparison operator to use when measuring a metric against the threshold value.final booleanfinal booleanequalsBySdkFields(Object obj) Indicates whether some other object is "equal to" this one by SDK fields.final IntegerLength of time (in minutes) the metric must be at or beyond the threshold before a scaling event is triggered.final StringfleetArn()The Amazon Resource Name (ARN) that is assigned to a Amazon GameLift Servers fleet resource and uniquely identifies it.final StringfleetId()A unique identifier for the fleet that is associated with this scaling policy.final <T> Optional<T> getValueForField(String fieldName, Class<T> clazz) final inthashCode()final Stringlocation()The fleet location.final MetricNameName of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment.final StringName of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment.final Stringname()A descriptive label that is associated with a fleet's scaling policy.final PolicyTypeThe type of scaling policy to create.final StringThe type of scaling policy to create.final IntegerAmount of adjustment to make, based on the scaling adjustment type.final ScalingAdjustmentTypeThe type of adjustment to make to a fleet's instance count.final StringThe type of adjustment to make to a fleet's instance count.static Class<? extends ScalingPolicy.Builder> final ScalingStatusTypestatus()Current status of the scaling policy.final StringCurrent status of the scaling policy.final TargetConfigurationAn object that contains settings for a target-based scaling policy.final DoubleMetric value used to trigger a scaling event.Take this object and create a builder that contains all of the current property values of this object.final StringtoString()Returns a string representation of this object.final LocationUpdateStatusThe current status of the fleet's scaling policies in a requested fleet location.final StringThe current status of the fleet's scaling policies in a requested fleet location.Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
Method Details
-
fleetId
A unique identifier for the fleet that is associated with this scaling policy.
- Returns:
- A unique identifier for the fleet that is associated with this scaling policy.
-
fleetArn
The Amazon Resource Name (ARN) that is assigned to a Amazon GameLift Servers fleet resource and uniquely identifies it. ARNs are unique across all Regions. Format is
arn:aws:gamelift:<region>::fleet/fleet-a1234567-b8c9-0d1e-2fa3-b45c6d7e8912.- Returns:
- The Amazon Resource Name (ARN) that is assigned to a
Amazon GameLift Servers fleet resource and uniquely identifies it. ARNs are unique across all Regions.
Format is
arn:aws:gamelift:<region>::fleet/fleet-a1234567-b8c9-0d1e-2fa3-b45c6d7e8912.
-
name
A descriptive label that is associated with a fleet's scaling policy. Policy names do not need to be unique.
- Returns:
- A descriptive label that is associated with a fleet's scaling policy. Policy names do not need to be unique.
-
status
Current status of the scaling policy. The scaling policy can be in force only when in an
ACTIVEstatus. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.-
ACTIVE -- The scaling policy can be used for auto-scaling a fleet.
-
UPDATE_REQUESTED -- A request to update the scaling policy has been received.
-
UPDATING -- A change is being made to the scaling policy.
-
DELETE_REQUESTED -- A request to delete the scaling policy has been received.
-
DELETING -- The scaling policy is being deleted.
-
DELETED -- The scaling policy has been deleted.
-
ERROR -- An error occurred in creating the policy. It should be removed and recreated.
If the service returns an enum value that is not available in the current SDK version,
statuswill returnScalingStatusType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromstatusAsString().- Returns:
- Current status of the scaling policy. The scaling policy can be in force only when in an
ACTIVEstatus. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.-
ACTIVE -- The scaling policy can be used for auto-scaling a fleet.
-
UPDATE_REQUESTED -- A request to update the scaling policy has been received.
-
UPDATING -- A change is being made to the scaling policy.
-
DELETE_REQUESTED -- A request to delete the scaling policy has been received.
-
DELETING -- The scaling policy is being deleted.
-
DELETED -- The scaling policy has been deleted.
-
ERROR -- An error occurred in creating the policy. It should be removed and recreated.
-
- See Also:
-
-
statusAsString
Current status of the scaling policy. The scaling policy can be in force only when in an
ACTIVEstatus. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.-
ACTIVE -- The scaling policy can be used for auto-scaling a fleet.
-
UPDATE_REQUESTED -- A request to update the scaling policy has been received.
-
UPDATING -- A change is being made to the scaling policy.
-
DELETE_REQUESTED -- A request to delete the scaling policy has been received.
-
DELETING -- The scaling policy is being deleted.
-
DELETED -- The scaling policy has been deleted.
-
ERROR -- An error occurred in creating the policy. It should be removed and recreated.
If the service returns an enum value that is not available in the current SDK version,
statuswill returnScalingStatusType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromstatusAsString().- Returns:
- Current status of the scaling policy. The scaling policy can be in force only when in an
ACTIVEstatus. Scaling policies can be suspended for individual fleets. If the policy is suspended for a fleet, the policy status does not change.-
ACTIVE -- The scaling policy can be used for auto-scaling a fleet.
-
UPDATE_REQUESTED -- A request to update the scaling policy has been received.
-
UPDATING -- A change is being made to the scaling policy.
-
DELETE_REQUESTED -- A request to delete the scaling policy has been received.
-
DELETING -- The scaling policy is being deleted.
-
DELETED -- The scaling policy has been deleted.
-
ERROR -- An error occurred in creating the policy. It should be removed and recreated.
-
- See Also:
-
-
scalingAdjustment
Amount of adjustment to make, based on the scaling adjustment type.
- Returns:
- Amount of adjustment to make, based on the scaling adjustment type.
-
scalingAdjustmentType
The type of adjustment to make to a fleet's instance count.
-
ChangeInCapacity -- add (or subtract) the scaling adjustment value from the current instance count. Positive values scale up while negative values scale down.
-
ExactCapacity -- set the instance count to the scaling adjustment value.
-
PercentChangeInCapacity -- increase or reduce the current instance count by the scaling adjustment, read as a percentage. Positive values scale up while negative values scale down.
If the service returns an enum value that is not available in the current SDK version,
scalingAdjustmentTypewill returnScalingAdjustmentType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromscalingAdjustmentTypeAsString().- Returns:
- The type of adjustment to make to a fleet's instance count.
-
ChangeInCapacity -- add (or subtract) the scaling adjustment value from the current instance count. Positive values scale up while negative values scale down.
-
ExactCapacity -- set the instance count to the scaling adjustment value.
-
PercentChangeInCapacity -- increase or reduce the current instance count by the scaling adjustment, read as a percentage. Positive values scale up while negative values scale down.
-
- See Also:
-
-
scalingAdjustmentTypeAsString
The type of adjustment to make to a fleet's instance count.
-
ChangeInCapacity -- add (or subtract) the scaling adjustment value from the current instance count. Positive values scale up while negative values scale down.
-
ExactCapacity -- set the instance count to the scaling adjustment value.
-
PercentChangeInCapacity -- increase or reduce the current instance count by the scaling adjustment, read as a percentage. Positive values scale up while negative values scale down.
If the service returns an enum value that is not available in the current SDK version,
scalingAdjustmentTypewill returnScalingAdjustmentType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromscalingAdjustmentTypeAsString().- Returns:
- The type of adjustment to make to a fleet's instance count.
-
ChangeInCapacity -- add (or subtract) the scaling adjustment value from the current instance count. Positive values scale up while negative values scale down.
-
ExactCapacity -- set the instance count to the scaling adjustment value.
-
PercentChangeInCapacity -- increase or reduce the current instance count by the scaling adjustment, read as a percentage. Positive values scale up while negative values scale down.
-
- See Also:
-
-
comparisonOperator
Comparison operator to use when measuring a metric against the threshold value.
If the service returns an enum value that is not available in the current SDK version,
comparisonOperatorwill returnComparisonOperatorType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromcomparisonOperatorAsString().- Returns:
- Comparison operator to use when measuring a metric against the threshold value.
- See Also:
-
comparisonOperatorAsString
Comparison operator to use when measuring a metric against the threshold value.
If the service returns an enum value that is not available in the current SDK version,
comparisonOperatorwill returnComparisonOperatorType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromcomparisonOperatorAsString().- Returns:
- Comparison operator to use when measuring a metric against the threshold value.
- See Also:
-
threshold
Metric value used to trigger a scaling event.
- Returns:
- Metric value used to trigger a scaling event.
-
evaluationPeriods
Length of time (in minutes) the metric must be at or beyond the threshold before a scaling event is triggered.
- Returns:
- Length of time (in minutes) the metric must be at or beyond the threshold before a scaling event is triggered.
-
metricName
Name of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment. For detailed descriptions of fleet metrics, see Monitor Amazon GameLift Servers with Amazon CloudWatch.
-
ActivatingGameSessions -- Game sessions in the process of being created.
-
ActiveGameSessions -- Game sessions that are currently running.
-
ActiveInstances -- Fleet instances that are currently running at least one game session.
-
AvailableGameSessions -- Additional game sessions that fleet could host simultaneously, given current capacity.
-
AvailablePlayerSessions -- Empty player slots in currently active game sessions. This includes game sessions that are not currently accepting players. Reserved player slots are not included.
-
CurrentPlayerSessions -- Player slots in active game sessions that are being used by a player or are reserved for a player.
-
IdleInstances -- Active instances that are currently hosting zero game sessions.
-
PercentAvailableGameSessions -- Unused percentage of the total number of game sessions that a fleet could host simultaneously, given current capacity. Use this metric for a target-based scaling policy.
-
PercentIdleInstances -- Percentage of the total number of active instances that are hosting zero game sessions.
-
QueueDepth -- Pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
WaitTime -- Current wait time for pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
If the service returns an enum value that is not available in the current SDK version,
metricNamewill returnMetricName.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available frommetricNameAsString().- Returns:
- Name of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment. For
detailed descriptions of fleet metrics, see Monitor
Amazon GameLift Servers with Amazon CloudWatch.
-
ActivatingGameSessions -- Game sessions in the process of being created.
-
ActiveGameSessions -- Game sessions that are currently running.
-
ActiveInstances -- Fleet instances that are currently running at least one game session.
-
AvailableGameSessions -- Additional game sessions that fleet could host simultaneously, given current capacity.
-
AvailablePlayerSessions -- Empty player slots in currently active game sessions. This includes game sessions that are not currently accepting players. Reserved player slots are not included.
-
CurrentPlayerSessions -- Player slots in active game sessions that are being used by a player or are reserved for a player.
-
IdleInstances -- Active instances that are currently hosting zero game sessions.
-
PercentAvailableGameSessions -- Unused percentage of the total number of game sessions that a fleet could host simultaneously, given current capacity. Use this metric for a target-based scaling policy.
-
PercentIdleInstances -- Percentage of the total number of active instances that are hosting zero game sessions.
-
QueueDepth -- Pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
WaitTime -- Current wait time for pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
- See Also:
-
-
metricNameAsString
Name of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment. For detailed descriptions of fleet metrics, see Monitor Amazon GameLift Servers with Amazon CloudWatch.
-
ActivatingGameSessions -- Game sessions in the process of being created.
-
ActiveGameSessions -- Game sessions that are currently running.
-
ActiveInstances -- Fleet instances that are currently running at least one game session.
-
AvailableGameSessions -- Additional game sessions that fleet could host simultaneously, given current capacity.
-
AvailablePlayerSessions -- Empty player slots in currently active game sessions. This includes game sessions that are not currently accepting players. Reserved player slots are not included.
-
CurrentPlayerSessions -- Player slots in active game sessions that are being used by a player or are reserved for a player.
-
IdleInstances -- Active instances that are currently hosting zero game sessions.
-
PercentAvailableGameSessions -- Unused percentage of the total number of game sessions that a fleet could host simultaneously, given current capacity. Use this metric for a target-based scaling policy.
-
PercentIdleInstances -- Percentage of the total number of active instances that are hosting zero game sessions.
-
QueueDepth -- Pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
WaitTime -- Current wait time for pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
If the service returns an enum value that is not available in the current SDK version,
metricNamewill returnMetricName.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available frommetricNameAsString().- Returns:
- Name of the Amazon GameLift Servers-defined metric that is used to trigger a scaling adjustment. For
detailed descriptions of fleet metrics, see Monitor
Amazon GameLift Servers with Amazon CloudWatch.
-
ActivatingGameSessions -- Game sessions in the process of being created.
-
ActiveGameSessions -- Game sessions that are currently running.
-
ActiveInstances -- Fleet instances that are currently running at least one game session.
-
AvailableGameSessions -- Additional game sessions that fleet could host simultaneously, given current capacity.
-
AvailablePlayerSessions -- Empty player slots in currently active game sessions. This includes game sessions that are not currently accepting players. Reserved player slots are not included.
-
CurrentPlayerSessions -- Player slots in active game sessions that are being used by a player or are reserved for a player.
-
IdleInstances -- Active instances that are currently hosting zero game sessions.
-
PercentAvailableGameSessions -- Unused percentage of the total number of game sessions that a fleet could host simultaneously, given current capacity. Use this metric for a target-based scaling policy.
-
PercentIdleInstances -- Percentage of the total number of active instances that are hosting zero game sessions.
-
QueueDepth -- Pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
WaitTime -- Current wait time for pending game session placement requests, in any queue, where the current fleet is the top-priority destination.
-
- See Also:
-
-
policyType
The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
If the service returns an enum value that is not available in the current SDK version,
policyTypewill returnPolicyType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available frompolicyTypeAsString().- Returns:
- The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
- See Also:
-
policyTypeAsString
The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
If the service returns an enum value that is not available in the current SDK version,
policyTypewill returnPolicyType.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available frompolicyTypeAsString().- Returns:
- The type of scaling policy to create. For a target-based policy, set the parameter MetricName to 'PercentAvailableGameSessions' and specify a TargetConfiguration. For a rule-based policy set the following parameters: MetricName, ComparisonOperator, Threshold, EvaluationPeriods, ScalingAdjustmentType, and ScalingAdjustment.
- See Also:
-
targetConfiguration
An object that contains settings for a target-based scaling policy.
- Returns:
- An object that contains settings for a target-based scaling policy.
-
updateStatus
The current status of the fleet's scaling policies in a requested fleet location. The status
PENDING_UPDATEindicates that an update was requested for the fleet but has not yet been completed for the location.If the service returns an enum value that is not available in the current SDK version,
updateStatuswill returnLocationUpdateStatus.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromupdateStatusAsString().- Returns:
- The current status of the fleet's scaling policies in a requested fleet location. The status
PENDING_UPDATEindicates that an update was requested for the fleet but has not yet been completed for the location. - See Also:
-
updateStatusAsString
The current status of the fleet's scaling policies in a requested fleet location. The status
PENDING_UPDATEindicates that an update was requested for the fleet but has not yet been completed for the location.If the service returns an enum value that is not available in the current SDK version,
updateStatuswill returnLocationUpdateStatus.UNKNOWN_TO_SDK_VERSION. The raw value returned by the service is available fromupdateStatusAsString().- Returns:
- The current status of the fleet's scaling policies in a requested fleet location. The status
PENDING_UPDATEindicates that an update was requested for the fleet but has not yet been completed for the location. - See Also:
-
location
-
toBuilder
Description copied from interface:ToCopyableBuilderTake this object and create a builder that contains all of the current property values of this object.- Specified by:
toBuilderin interfaceToCopyableBuilder<ScalingPolicy.Builder,ScalingPolicy> - Returns:
- a builder for type T
-
builder
-
serializableBuilderClass
-
hashCode
-
equals
-
equalsBySdkFields
Description copied from interface:SdkPojoIndicates whether some other object is "equal to" this one by SDK fields. An SDK field is a modeled, non-inherited field in anSdkPojoclass, and is generated based on a service model.If an
SdkPojoclass does not have any inherited fields,equalsBySdkFieldsandequalsare essentially the same.- Specified by:
equalsBySdkFieldsin interfaceSdkPojo- Parameters:
obj- the object to be compared with- Returns:
- true if the other object equals to this object by sdk fields, false otherwise.
-
toString
-
getValueForField
-
sdkFields
-
sdkFieldNameToField
- Specified by:
sdkFieldNameToFieldin interfaceSdkPojo- Returns:
- The mapping between the field name and its corresponding field.
-