GetRecommendation
Returns both the current and recommended resource configuration and the estimated cost impact for a recommendation.
The recommendationId
is only valid for up to a maximum of 24 hours as
recommendations are refreshed daily. To retrieve the recommendationId
, use the
ListRecommendations
API.
Request Syntax
{
"recommendationId": "string
"
}
Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
- recommendationId
-
The ID for the recommendation.
Type: String
Required: Yes
Response Syntax
{
"accountId": "string",
"actionType": "string",
"costCalculationLookbackPeriodInDays": number,
"currencyCode": "string",
"currentResourceDetails": { ... },
"currentResourceType": "string",
"estimatedMonthlyCost": number,
"estimatedMonthlySavings": number,
"estimatedSavingsOverCostCalculationLookbackPeriod": number,
"estimatedSavingsPercentage": number,
"implementationEffort": "string",
"lastRefreshTimestamp": number,
"recommendationId": "string",
"recommendationLookbackPeriodInDays": number,
"recommendedResourceDetails": { ... },
"recommendedResourceType": "string",
"region": "string",
"resourceArn": "string",
"resourceId": "string",
"restartNeeded": boolean,
"rollbackPossible": boolean,
"source": "string",
"tags": [
{
"key": "string",
"value": "string"
}
]
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
- accountId
-
The account that the recommendation is for.
Type: String
- actionType
-
The type of action you can take by adopting the recommendation.
Type: String
Valid Values:
Rightsize | Stop | Upgrade | PurchaseSavingsPlans | PurchaseReservedInstances | MigrateToGraviton | Delete
- costCalculationLookbackPeriodInDays
-
The lookback period used to calculate cost impact for a recommendation.
Type: Integer
- currencyCode
-
The currency code used for the recommendation.
Type: String
- currentResourceDetails
-
The details for the resource.
Type: ResourceDetails object
Note: This object is a Union. Only one member of this object can be specified or returned.
- currentResourceType
-
The type of resource.
Type: String
Valid Values:
Ec2Instance | LambdaFunction | EbsVolume | EcsService | Ec2AutoScalingGroup | Ec2InstanceSavingsPlans | ComputeSavingsPlans | SageMakerSavingsPlans | Ec2ReservedInstances | RdsReservedInstances | OpenSearchReservedInstances | RedshiftReservedInstances | ElastiCacheReservedInstances | RdsDbInstanceStorage | RdsDbInstance
- estimatedMonthlyCost
-
The estimated monthly cost of the current resource. For Reserved Instances and Savings Plans, it refers to the cost for eligible usage.
Type: Double
- estimatedMonthlySavings
-
The estimated monthly savings amount for the recommendation.
Type: Double
- estimatedSavingsOverCostCalculationLookbackPeriod
-
The estimated savings amount over the lookback period used to calculate cost impact for a recommendation.
Type: Double
- estimatedSavingsPercentage
-
The estimated savings percentage relative to the total cost over the cost calculation lookback period.
Type: Double
- implementationEffort
-
The effort required to implement the recommendation.
Type: String
Valid Values:
VeryLow | Low | Medium | High | VeryHigh
- lastRefreshTimestamp
-
The time when the recommendation was last generated.
Type: Timestamp
- recommendationId
-
The ID for the recommendation.
Type: String
- recommendationLookbackPeriodInDays
-
The lookback period that's used to generate the recommendation.
Type: Integer
- recommendedResourceDetails
-
The details about the recommended resource.
Type: ResourceDetails object
Note: This object is a Union. Only one member of this object can be specified or returned.
- recommendedResourceType
-
The resource type of the recommendation.
Type: String
Valid Values:
Ec2Instance | LambdaFunction | EbsVolume | EcsService | Ec2AutoScalingGroup | Ec2InstanceSavingsPlans | ComputeSavingsPlans | SageMakerSavingsPlans | Ec2ReservedInstances | RdsReservedInstances | OpenSearchReservedInstances | RedshiftReservedInstances | ElastiCacheReservedInstances | RdsDbInstanceStorage | RdsDbInstance
- region
-
The AWS Region of the resource.
Type: String
- resourceArn
-
The Amazon Resource Name (ARN) of the resource.
Type: String
- resourceId
-
The unique identifier for the resource. This is the same as the Amazon Resource Name (ARN), if available.
Type: String
- restartNeeded
-
Whether or not implementing the recommendation requires a restart.
Type: Boolean
- rollbackPossible
-
Whether or not implementing the recommendation can be rolled back.
Type: Boolean
- source
-
The source of the recommendation.
Type: String
Valid Values:
ComputeOptimizer | CostExplorer
-
A list of tags associated with the resource for which the recommendation exists.
Type: Array of Tag objects
Array Members: Minimum number of 1 item. Maximum number of 100 items.
Errors
For information about the errors that are common to all actions, see Common Errors.
- AccessDeniedException
-
You are not authorized to use this operation with the given parameters.
HTTP Status Code: 400
- InternalServerException
-
An error on the server occurred during the processing of your request. Try again later.
HTTP Status Code: 500
- ResourceNotFoundException
-
The specified Amazon Resource Name (ARN) in the request doesn't exist.
HTTP Status Code: 400
- ThrottlingException
-
The request was denied due to request throttling.
HTTP Status Code: 400
- ValidationException
-
The input fails to satisfy the constraints specified by an AWS service.
HTTP Status Code: 400
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: