Struct aws_sdk_computeoptimizer::operation::put_recommendation_preferences::builders::PutRecommendationPreferencesFluentBuilder
source · pub struct PutRecommendationPreferencesFluentBuilder { /* private fields */ }
Expand description
Fluent builder constructing a request to PutRecommendationPreferences
.
Creates a new recommendation preference or updates an existing recommendation preference, such as enhanced infrastructure metrics.
For more information, see Activating enhanced infrastructure metrics in the Compute Optimizer User Guide.
Implementations§
source§impl PutRecommendationPreferencesFluentBuilder
impl PutRecommendationPreferencesFluentBuilder
sourcepub fn as_input(&self) -> &PutRecommendationPreferencesInputBuilder
pub fn as_input(&self) -> &PutRecommendationPreferencesInputBuilder
Access the PutRecommendationPreferences as a reference.
sourcepub async fn send(
self
) -> Result<PutRecommendationPreferencesOutput, SdkError<PutRecommendationPreferencesError, HttpResponse>>
pub async fn send( self ) -> Result<PutRecommendationPreferencesOutput, SdkError<PutRecommendationPreferencesError, HttpResponse>>
Sends the request and returns the response.
If an error occurs, an SdkError
will be returned with additional details that
can be matched against.
By default, any retryable failures will be retried twice. Retry behavior is configurable with the RetryConfig, which can be set when configuring the client.
sourcepub fn customize(
self
) -> CustomizableOperation<PutRecommendationPreferencesOutput, PutRecommendationPreferencesError, Self>
pub fn customize( self ) -> CustomizableOperation<PutRecommendationPreferencesOutput, PutRecommendationPreferencesError, Self>
Consumes this builder, creating a customizable operation that can be modified before being sent.
sourcepub fn resource_type(self, input: ResourceType) -> Self
pub fn resource_type(self, input: ResourceType) -> Self
The target resource type of the recommendation preference to create.
The Ec2Instance
option encompasses standalone instances and instances that are part of Auto Scaling groups. The AutoScalingGroup
option encompasses only instances that are part of an Auto Scaling group.
The valid values for this parameter are Ec2Instance
and AutoScalingGroup
.
sourcepub fn set_resource_type(self, input: Option<ResourceType>) -> Self
pub fn set_resource_type(self, input: Option<ResourceType>) -> Self
The target resource type of the recommendation preference to create.
The Ec2Instance
option encompasses standalone instances and instances that are part of Auto Scaling groups. The AutoScalingGroup
option encompasses only instances that are part of an Auto Scaling group.
The valid values for this parameter are Ec2Instance
and AutoScalingGroup
.
sourcepub fn get_resource_type(&self) -> &Option<ResourceType>
pub fn get_resource_type(&self) -> &Option<ResourceType>
The target resource type of the recommendation preference to create.
The Ec2Instance
option encompasses standalone instances and instances that are part of Auto Scaling groups. The AutoScalingGroup
option encompasses only instances that are part of an Auto Scaling group.
The valid values for this parameter are Ec2Instance
and AutoScalingGroup
.
sourcepub fn scope(self, input: Scope) -> Self
pub fn scope(self, input: Scope) -> Self
An object that describes the scope of the recommendation preference to create.
You can create recommendation preferences at the organization level (for management accounts of an organization only), account level, and resource level. For more information, see Activating enhanced infrastructure metrics in the Compute Optimizer User Guide.
You cannot create recommendation preferences for Auto Scaling groups at the organization and account levels. You can create recommendation preferences for Auto Scaling groups only at the resource level by specifying a scope name of ResourceArn
and a scope value of the Auto Scaling group Amazon Resource Name (ARN). This will configure the preference for all instances that are part of the specified Auto Scaling group. You also cannot create recommendation preferences at the resource level for instances that are part of an Auto Scaling group. You can create recommendation preferences at the resource level only for standalone instances.
sourcepub fn set_scope(self, input: Option<Scope>) -> Self
pub fn set_scope(self, input: Option<Scope>) -> Self
An object that describes the scope of the recommendation preference to create.
You can create recommendation preferences at the organization level (for management accounts of an organization only), account level, and resource level. For more information, see Activating enhanced infrastructure metrics in the Compute Optimizer User Guide.
You cannot create recommendation preferences for Auto Scaling groups at the organization and account levels. You can create recommendation preferences for Auto Scaling groups only at the resource level by specifying a scope name of ResourceArn
and a scope value of the Auto Scaling group Amazon Resource Name (ARN). This will configure the preference for all instances that are part of the specified Auto Scaling group. You also cannot create recommendation preferences at the resource level for instances that are part of an Auto Scaling group. You can create recommendation preferences at the resource level only for standalone instances.
sourcepub fn get_scope(&self) -> &Option<Scope>
pub fn get_scope(&self) -> &Option<Scope>
An object that describes the scope of the recommendation preference to create.
You can create recommendation preferences at the organization level (for management accounts of an organization only), account level, and resource level. For more information, see Activating enhanced infrastructure metrics in the Compute Optimizer User Guide.
You cannot create recommendation preferences for Auto Scaling groups at the organization and account levels. You can create recommendation preferences for Auto Scaling groups only at the resource level by specifying a scope name of ResourceArn
and a scope value of the Auto Scaling group Amazon Resource Name (ARN). This will configure the preference for all instances that are part of the specified Auto Scaling group. You also cannot create recommendation preferences at the resource level for instances that are part of an Auto Scaling group. You can create recommendation preferences at the resource level only for standalone instances.
sourcepub fn enhanced_infrastructure_metrics(
self,
input: EnhancedInfrastructureMetrics
) -> Self
pub fn enhanced_infrastructure_metrics( self, input: EnhancedInfrastructureMetrics ) -> Self
The status of the enhanced infrastructure metrics recommendation preference to create or update.
Specify the Active
status to activate the preference, or specify Inactive
to deactivate the preference.
For more information, see Enhanced infrastructure metrics in the Compute Optimizer User Guide.
sourcepub fn set_enhanced_infrastructure_metrics(
self,
input: Option<EnhancedInfrastructureMetrics>
) -> Self
pub fn set_enhanced_infrastructure_metrics( self, input: Option<EnhancedInfrastructureMetrics> ) -> Self
The status of the enhanced infrastructure metrics recommendation preference to create or update.
Specify the Active
status to activate the preference, or specify Inactive
to deactivate the preference.
For more information, see Enhanced infrastructure metrics in the Compute Optimizer User Guide.
sourcepub fn get_enhanced_infrastructure_metrics(
&self
) -> &Option<EnhancedInfrastructureMetrics>
pub fn get_enhanced_infrastructure_metrics( &self ) -> &Option<EnhancedInfrastructureMetrics>
The status of the enhanced infrastructure metrics recommendation preference to create or update.
Specify the Active
status to activate the preference, or specify Inactive
to deactivate the preference.
For more information, see Enhanced infrastructure metrics in the Compute Optimizer User Guide.
sourcepub fn inferred_workload_types(
self,
input: InferredWorkloadTypesPreference
) -> Self
pub fn inferred_workload_types( self, input: InferredWorkloadTypesPreference ) -> Self
The status of the inferred workload types recommendation preference to create or update.
The inferred workload type feature is active by default. To deactivate it, create a recommendation preference.
Specify the Inactive
status to deactivate the feature, or specify Active
to activate it.
For more information, see Inferred workload types in the Compute Optimizer User Guide.
sourcepub fn set_inferred_workload_types(
self,
input: Option<InferredWorkloadTypesPreference>
) -> Self
pub fn set_inferred_workload_types( self, input: Option<InferredWorkloadTypesPreference> ) -> Self
The status of the inferred workload types recommendation preference to create or update.
The inferred workload type feature is active by default. To deactivate it, create a recommendation preference.
Specify the Inactive
status to deactivate the feature, or specify Active
to activate it.
For more information, see Inferred workload types in the Compute Optimizer User Guide.
sourcepub fn get_inferred_workload_types(
&self
) -> &Option<InferredWorkloadTypesPreference>
pub fn get_inferred_workload_types( &self ) -> &Option<InferredWorkloadTypesPreference>
The status of the inferred workload types recommendation preference to create or update.
The inferred workload type feature is active by default. To deactivate it, create a recommendation preference.
Specify the Inactive
status to deactivate the feature, or specify Active
to activate it.
For more information, see Inferred workload types in the Compute Optimizer User Guide.
sourcepub fn external_metrics_preference(
self,
input: ExternalMetricsPreference
) -> Self
pub fn external_metrics_preference( self, input: ExternalMetricsPreference ) -> Self
The provider of the external metrics recommendation preference to create or update.
Specify a valid provider in the source
field to activate the preference. To delete this preference, see the DeleteRecommendationPreferences
action.
This preference can only be set for the Ec2Instance
resource type.
For more information, see External metrics ingestion in the Compute Optimizer User Guide.
sourcepub fn set_external_metrics_preference(
self,
input: Option<ExternalMetricsPreference>
) -> Self
pub fn set_external_metrics_preference( self, input: Option<ExternalMetricsPreference> ) -> Self
The provider of the external metrics recommendation preference to create or update.
Specify a valid provider in the source
field to activate the preference. To delete this preference, see the DeleteRecommendationPreferences
action.
This preference can only be set for the Ec2Instance
resource type.
For more information, see External metrics ingestion in the Compute Optimizer User Guide.
sourcepub fn get_external_metrics_preference(
&self
) -> &Option<ExternalMetricsPreference>
pub fn get_external_metrics_preference( &self ) -> &Option<ExternalMetricsPreference>
The provider of the external metrics recommendation preference to create or update.
Specify a valid provider in the source
field to activate the preference. To delete this preference, see the DeleteRecommendationPreferences
action.
This preference can only be set for the Ec2Instance
resource type.
For more information, see External metrics ingestion in the Compute Optimizer User Guide.
sourcepub fn look_back_period(self, input: LookBackPeriodPreference) -> Self
pub fn look_back_period(self, input: LookBackPeriodPreference) -> Self
The preference to control the number of days the utilization metrics of the Amazon Web Services resource are analyzed. When this preference isn't specified, we use the default value DAYS_14
.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn set_look_back_period(
self,
input: Option<LookBackPeriodPreference>
) -> Self
pub fn set_look_back_period( self, input: Option<LookBackPeriodPreference> ) -> Self
The preference to control the number of days the utilization metrics of the Amazon Web Services resource are analyzed. When this preference isn't specified, we use the default value DAYS_14
.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn get_look_back_period(&self) -> &Option<LookBackPeriodPreference>
pub fn get_look_back_period(&self) -> &Option<LookBackPeriodPreference>
The preference to control the number of days the utilization metrics of the Amazon Web Services resource are analyzed. When this preference isn't specified, we use the default value DAYS_14
.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn utilization_preferences(self, input: UtilizationPreference) -> Self
pub fn utilization_preferences(self, input: UtilizationPreference) -> Self
Appends an item to utilizationPreferences
.
To override the contents of this collection use set_utilization_preferences
.
The preference to control the resource’s CPU utilization threshold, CPU utilization headroom, and memory utilization headroom. When this preference isn't specified, we use the following default values.
CPU utilization:
-
P99_5
for threshold -
PERCENT_20
for headroom
Memory utilization:
-
PERCENT_20
for headroom
-
You can only set CPU and memory utilization preferences for the Amazon EC2 instance resource type.
-
The threshold setting isn’t available for memory utilization.
sourcepub fn set_utilization_preferences(
self,
input: Option<Vec<UtilizationPreference>>
) -> Self
pub fn set_utilization_preferences( self, input: Option<Vec<UtilizationPreference>> ) -> Self
The preference to control the resource’s CPU utilization threshold, CPU utilization headroom, and memory utilization headroom. When this preference isn't specified, we use the following default values.
CPU utilization:
-
P99_5
for threshold -
PERCENT_20
for headroom
Memory utilization:
-
PERCENT_20
for headroom
-
You can only set CPU and memory utilization preferences for the Amazon EC2 instance resource type.
-
The threshold setting isn’t available for memory utilization.
sourcepub fn get_utilization_preferences(&self) -> &Option<Vec<UtilizationPreference>>
pub fn get_utilization_preferences(&self) -> &Option<Vec<UtilizationPreference>>
The preference to control the resource’s CPU utilization threshold, CPU utilization headroom, and memory utilization headroom. When this preference isn't specified, we use the following default values.
CPU utilization:
-
P99_5
for threshold -
PERCENT_20
for headroom
Memory utilization:
-
PERCENT_20
for headroom
-
You can only set CPU and memory utilization preferences for the Amazon EC2 instance resource type.
-
The threshold setting isn’t available for memory utilization.
sourcepub fn preferred_resources(self, input: PreferredResource) -> Self
pub fn preferred_resources(self, input: PreferredResource) -> Self
Appends an item to preferredResources
.
To override the contents of this collection use set_preferred_resources
.
The preference to control which resource type values are considered when generating rightsizing recommendations. You can specify this preference as a combination of include and exclude lists. You must specify either an includeList
or excludeList
. If the preference is an empty set of resource type values, an error occurs.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn set_preferred_resources(
self,
input: Option<Vec<PreferredResource>>
) -> Self
pub fn set_preferred_resources( self, input: Option<Vec<PreferredResource>> ) -> Self
The preference to control which resource type values are considered when generating rightsizing recommendations. You can specify this preference as a combination of include and exclude lists. You must specify either an includeList
or excludeList
. If the preference is an empty set of resource type values, an error occurs.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn get_preferred_resources(&self) -> &Option<Vec<PreferredResource>>
pub fn get_preferred_resources(&self) -> &Option<Vec<PreferredResource>>
The preference to control which resource type values are considered when generating rightsizing recommendations. You can specify this preference as a combination of include and exclude lists. You must specify either an includeList
or excludeList
. If the preference is an empty set of resource type values, an error occurs.
You can only set this preference for the Amazon EC2 instance and Auto Scaling group resource types.
sourcepub fn savings_estimation_mode(self, input: SavingsEstimationMode) -> Self
pub fn savings_estimation_mode(self, input: SavingsEstimationMode) -> Self
The status of the savings estimation mode preference to create or update.
Specify the AfterDiscounts
status to activate the preference, or specify BeforeDiscounts
to deactivate the preference.
Only the account manager or delegated administrator of your organization can activate this preference.
For more information, see Savings estimation mode in the Compute Optimizer User Guide.
sourcepub fn set_savings_estimation_mode(
self,
input: Option<SavingsEstimationMode>
) -> Self
pub fn set_savings_estimation_mode( self, input: Option<SavingsEstimationMode> ) -> Self
The status of the savings estimation mode preference to create or update.
Specify the AfterDiscounts
status to activate the preference, or specify BeforeDiscounts
to deactivate the preference.
Only the account manager or delegated administrator of your organization can activate this preference.
For more information, see Savings estimation mode in the Compute Optimizer User Guide.
sourcepub fn get_savings_estimation_mode(&self) -> &Option<SavingsEstimationMode>
pub fn get_savings_estimation_mode(&self) -> &Option<SavingsEstimationMode>
The status of the savings estimation mode preference to create or update.
Specify the AfterDiscounts
status to activate the preference, or specify BeforeDiscounts
to deactivate the preference.
Only the account manager or delegated administrator of your organization can activate this preference.
For more information, see Savings estimation mode in the Compute Optimizer User Guide.
Trait Implementations§
source§impl Clone for PutRecommendationPreferencesFluentBuilder
impl Clone for PutRecommendationPreferencesFluentBuilder
source§fn clone(&self) -> PutRecommendationPreferencesFluentBuilder
fn clone(&self) -> PutRecommendationPreferencesFluentBuilder
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl Freeze for PutRecommendationPreferencesFluentBuilder
impl !RefUnwindSafe for PutRecommendationPreferencesFluentBuilder
impl Send for PutRecommendationPreferencesFluentBuilder
impl Sync for PutRecommendationPreferencesFluentBuilder
impl Unpin for PutRecommendationPreferencesFluentBuilder
impl !UnwindSafe for PutRecommendationPreferencesFluentBuilder
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more