startInstanceRefresh method
- required String autoScalingGroupName,
- RefreshPreferences? preferences,
- RefreshStrategy? strategy,
Starts a new instance refresh operation, which triggers a rolling replacement of all previously launched instances in the Auto Scaling group with a new group of instances.
If successful, this call creates a new instance refresh request with a unique ID that you can use to track its progress. To query its status, call the DescribeInstanceRefreshes API. To describe the instance refreshes that have already run, call the DescribeInstanceRefreshes API. To cancel an instance refresh operation in progress, use the CancelInstanceRefresh API.
For more information, see Replacing Auto Scaling Instances Based on an Instance Refresh.
May throw LimitExceededFault. May throw ResourceContentionFault. May throw InstanceRefreshInProgressFault.
Parameter autoScalingGroupName
:
The name of the Auto Scaling group.
Parameter preferences
:
Set of preferences associated with the instance refresh request.
If not provided, the default values are used. For
MinHealthyPercentage
, the default value is 90
.
For InstanceWarmup
, the default is to use the value specified
for the health check grace period for the Auto Scaling group.
For more information, see RefreshPreferences in the Amazon EC2 Auto Scaling API Reference.
Parameter strategy
:
The strategy to use for the instance refresh. The only valid value is
Rolling
.
A rolling update is an update that is applied to all instances in an Auto Scaling group until all instances have been updated. A rolling update can fail due to failed health checks or if instances are on standby or are protected from scale in. If the rolling update process fails, any instances that were already replaced are not rolled back to their previous configuration.
Implementation
Future<StartInstanceRefreshAnswer> startInstanceRefresh({
required String autoScalingGroupName,
RefreshPreferences? preferences,
RefreshStrategy? strategy,
}) async {
ArgumentError.checkNotNull(autoScalingGroupName, 'autoScalingGroupName');
_s.validateStringLength(
'autoScalingGroupName',
autoScalingGroupName,
1,
255,
isRequired: true,
);
final $request = <String, dynamic>{};
$request['AutoScalingGroupName'] = autoScalingGroupName;
preferences?.also((arg) => $request['Preferences'] = arg);
strategy?.also((arg) => $request['Strategy'] = arg.toValue());
final $result = await _protocol.send(
$request,
action: 'StartInstanceRefresh',
version: '2011-01-01',
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
shape: shapes['StartInstanceRefreshType'],
shapes: shapes,
resultWrapper: 'StartInstanceRefreshResult',
);
return StartInstanceRefreshAnswer.fromXml($result);
}