:doc:`ComputeOptimizer <../../compute-optimizer>` / Client / export_auto_scaling_group_recommendations

*****************************************
export_auto_scaling_group_recommendations
*****************************************



.. py:method:: ComputeOptimizer.Client.export_auto_scaling_group_recommendations(**kwargs)

  

  Exports optimization recommendations for Amazon EC2 Auto Scaling groups.

   

  Recommendations are exported in a comma-separated values (.csv) file, and its metadata in a JavaScript Object Notation (JSON) (.json) file, to an existing Amazon Simple Storage Service (Amazon S3) bucket that you specify. For more information, see `Exporting Recommendations <https://docs.aws.amazon.com/compute-optimizer/latest/ug/exporting-recommendations.html>`__ in the *Compute Optimizer User Guide*.

   

  You can have only one Amazon EC2 Auto Scaling group export job in progress per Amazon Web Services Region.

  

  See also: `AWS API Documentation <https://docs.aws.amazon.com/goto/WebAPI/compute-optimizer-2019-11-01/ExportAutoScalingGroupRecommendations>`_  


  **Request Syntax**
  ::

    response = client.export_auto_scaling_group_recommendations(
        accountIds=[
            'string',
        ],
        filters=[
            {
                'name': 'Finding'|'FindingReasonCodes'|'RecommendationSourceType'|'InferredWorkloadTypes',
                'values': [
                    'string',
                ]
            },
        ],
        fieldsToExport=[
            'AccountId'|'AutoScalingGroupArn'|'AutoScalingGroupName'|'Finding'|'UtilizationMetricsCpuMaximum'|'UtilizationMetricsMemoryMaximum'|'UtilizationMetricsEbsReadOpsPerSecondMaximum'|'UtilizationMetricsEbsWriteOpsPerSecondMaximum'|'UtilizationMetricsEbsReadBytesPerSecondMaximum'|'UtilizationMetricsEbsWriteBytesPerSecondMaximum'|'UtilizationMetricsDiskReadOpsPerSecondMaximum'|'UtilizationMetricsDiskWriteOpsPerSecondMaximum'|'UtilizationMetricsDiskReadBytesPerSecondMaximum'|'UtilizationMetricsDiskWriteBytesPerSecondMaximum'|'UtilizationMetricsNetworkInBytesPerSecondMaximum'|'UtilizationMetricsNetworkOutBytesPerSecondMaximum'|'UtilizationMetricsNetworkPacketsInPerSecondMaximum'|'UtilizationMetricsNetworkPacketsOutPerSecondMaximum'|'LookbackPeriodInDays'|'CurrentConfigurationInstanceType'|'CurrentConfigurationDesiredCapacity'|'CurrentConfigurationMinSize'|'CurrentConfigurationMaxSize'|'CurrentConfigurationAllocationStrategy'|'CurrentConfigurationMixedInstanceTypes'|'CurrentConfigurationType'|'CurrentOnDemandPrice'|'CurrentStandardOneYearNoUpfrontReservedPrice'|'CurrentStandardThreeYearNoUpfrontReservedPrice'|'CurrentVCpus'|'CurrentMemory'|'CurrentStorage'|'CurrentNetwork'|'RecommendationOptionsConfigurationInstanceType'|'RecommendationOptionsConfigurationDesiredCapacity'|'RecommendationOptionsConfigurationMinSize'|'RecommendationOptionsConfigurationMaxSize'|'RecommendationOptionsConfigurationEstimatedInstanceHourReductionPercentage'|'RecommendationOptionsConfigurationAllocationStrategy'|'RecommendationOptionsConfigurationMixedInstanceTypes'|'RecommendationOptionsConfigurationType'|'RecommendationOptionsProjectedUtilizationMetricsCpuMaximum'|'RecommendationOptionsProjectedUtilizationMetricsMemoryMaximum'|'RecommendationOptionsPerformanceRisk'|'RecommendationOptionsOnDemandPrice'|'RecommendationOptionsStandardOneYearNoUpfrontReservedPrice'|'RecommendationOptionsStandardThreeYearNoUpfrontReservedPrice'|'RecommendationOptionsVcpus'|'RecommendationOptionsMemory'|'RecommendationOptionsStorage'|'RecommendationOptionsNetwork'|'LastRefreshTimestamp'|'CurrentPerformanceRisk'|'RecommendationOptionsSavingsOpportunityPercentage'|'RecommendationOptionsEstimatedMonthlySavingsCurrency'|'RecommendationOptionsEstimatedMonthlySavingsValue'|'EffectiveRecommendationPreferencesCpuVendorArchitectures'|'EffectiveRecommendationPreferencesEnhancedInfrastructureMetrics'|'EffectiveRecommendationPreferencesInferredWorkloadTypes'|'EffectiveRecommendationPreferencesPreferredResources'|'EffectiveRecommendationPreferencesLookBackPeriod'|'InferredWorkloadTypes'|'RecommendationOptionsMigrationEffort'|'CurrentInstanceGpuInfo'|'RecommendationOptionsInstanceGpuInfo'|'UtilizationMetricsGpuPercentageMaximum'|'UtilizationMetricsGpuMemoryPercentageMaximum'|'RecommendationOptionsProjectedUtilizationMetricsGpuPercentageMaximum'|'RecommendationOptionsProjectedUtilizationMetricsGpuMemoryPercentageMaximum'|'EffectiveRecommendationPreferencesSavingsEstimationMode'|'RecommendationOptionsSavingsOpportunityAfterDiscountsPercentage'|'RecommendationOptionsEstimatedMonthlySavingsCurrencyAfterDiscounts'|'RecommendationOptionsEstimatedMonthlySavingsValueAfterDiscounts',
        ],
        s3DestinationConfig={
            'bucket': 'string',
            'keyPrefix': 'string'
        },
        fileFormat='Csv',
        includeMemberAccounts=True|False,
        recommendationPreferences={
            'cpuVendorArchitectures': [
                'AWS_ARM64'|'CURRENT',
            ]
        }
    )
    
  :type accountIds: list
  :param accountIds: 

    The IDs of the Amazon Web Services accounts for which to export Amazon EC2 Auto Scaling group recommendations.

     

    If your account is the management account of an organization, use this parameter to specify the member account for which you want to export recommendations.

     

    This parameter cannot be specified together with the include member accounts parameter. The parameters are mutually exclusive.

     

    Recommendations for member accounts are not included in the export if this parameter, or the include member accounts parameter, is omitted.

     

    You can specify multiple account IDs per request.

    

  
    - *(string) --* 

    

  :type filters: list
  :param filters: 

    An array of objects to specify a filter that exports a more specific set of Amazon EC2 Auto Scaling group recommendations.

    

  
    - *(dict) --* 

      Describes a filter that returns a more specific list of recommendations. Use this filter with the  GetAutoScalingGroupRecommendations and  GetEC2InstanceRecommendations actions.

       

      You can use ``EBSFilter`` with the  GetEBSVolumeRecommendations action, ``LambdaFunctionRecommendationFilter`` with the  GetLambdaFunctionRecommendations action, and ``JobFilter`` with the  DescribeRecommendationExportJobs action.

      

    
      - **name** *(string) --* 

        The name of the filter.

         

        Specify ``Finding`` to return recommendations with a specific finding classification. For example, ``Underprovisioned``.

         

        Specify ``RecommendationSourceType`` to return recommendations of a specific resource type. For example, ``Ec2Instance``.

         

        Specify ``FindingReasonCodes`` to return recommendations with a specific finding reason code. For example, ``CPUUnderprovisioned``.

         

        Specify ``InferredWorkloadTypes`` to return recommendations of a specific inferred workload. For example, ``Redis``.

         

        You can filter your EC2 instance recommendations by ``tag:key`` and ``tag-key`` tags.

         

        A ``tag:key`` is a key and value combination of a tag assigned to your recommendations. Use the tag key in the filter name and the tag value as the filter value. For example, to find all recommendations that have a tag with the key of ``Owner`` and the value of ``TeamA``, specify ``tag:Owner`` for the filter name and ``TeamA`` for the filter value.

         

        A ``tag-key`` is the key of a tag assigned to your recommendations. Use this filter to find all of your recommendations that have a tag with a specific key. This doesn’t consider the tag value. For example, you can find your recommendations with a tag key value of ``Owner`` or without any tag keys assigned.

        

      
      - **values** *(list) --* 

        The value of the filter.

         

        The valid values for this parameter are as follows, depending on what you specify for the ``name`` parameter and the resource type that you wish to filter results for:

         

        
        * Specify ``Optimized`` or ``NotOptimized`` if you specify the ``name`` parameter as ``Finding`` and you want to filter results for Amazon EC2 Auto Scaling groups.
         
        * Specify ``Underprovisioned``, ``Overprovisioned``, or ``Optimized`` if you specify the ``name`` parameter as ``Finding`` and you want to filter results for EC2 instances.
         
        * Specify ``Ec2Instance`` or ``AutoScalingGroup`` if you specify the ``name`` parameter as ``RecommendationSourceType``.
         
        * Specify one of the following options if you specify the ``name`` parameter as ``FindingReasonCodes``: 

          
          * ``CPUOverprovisioned`` — The instance’s CPU configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``CPUUnderprovisioned`` — The instance’s CPU configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better CPU performance.
           
          * ``MemoryOverprovisioned`` — The instance’s memory configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``MemoryUnderprovisioned`` — The instance’s memory configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better memory performance.
           
          * ``EBSThroughputOverprovisioned`` — The instance’s EBS throughput configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``EBSThroughputUnderprovisioned`` — The instance’s EBS throughput configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better EBS throughput performance.
           
          * ``EBSIOPSOverprovisioned`` — The instance’s EBS IOPS configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``EBSIOPSUnderprovisioned`` — The instance’s EBS IOPS configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better EBS IOPS performance.
           
          * ``NetworkBandwidthOverprovisioned`` — The instance’s network bandwidth configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``NetworkBandwidthUnderprovisioned`` — The instance’s network bandwidth configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better network bandwidth performance. This finding reason happens when the ``NetworkIn`` or ``NetworkOut`` performance of an instance is impacted.
           
          * ``NetworkPPSOverprovisioned`` — The instance’s network PPS (packets per second) configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``NetworkPPSUnderprovisioned`` — The instance’s network PPS (packets per second) configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better network PPS performance.
           
          * ``DiskIOPSOverprovisioned`` — The instance’s disk IOPS configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``DiskIOPSUnderprovisioned`` — The instance’s disk IOPS configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better disk IOPS performance.
           
          * ``DiskThroughputOverprovisioned`` — The instance’s disk throughput configuration can be sized down while still meeting the performance requirements of your workload.
           
          * ``DiskThroughputUnderprovisioned`` — The instance’s disk throughput configuration doesn't meet the performance requirements of your workload and there is an alternative instance type that provides better disk throughput performance.
          

        
        

        

      
        - *(string) --* 

        
    
    

  :type fieldsToExport: list
  :param fieldsToExport: 

    The recommendations data to include in the export file. For more information about the fields that can be exported, see `Exported files <https://docs.aws.amazon.com/compute-optimizer/latest/ug/exporting-recommendations.html#exported-files>`__ in the *Compute Optimizer User Guide*.

    

  
    - *(string) --* 

    

  :type s3DestinationConfig: dict
  :param s3DestinationConfig: **[REQUIRED]** 

    An object to specify the destination Amazon Simple Storage Service (Amazon S3) bucket name and key prefix for the export job.

     

    You must create the destination Amazon S3 bucket for your recommendations export before you create the export job. Compute Optimizer does not create the S3 bucket for you. After you create the S3 bucket, ensure that it has the required permissions policy to allow Compute Optimizer to write the export file to it. If you plan to specify an object prefix when you create the export job, you must include the object prefix in the policy that you add to the S3 bucket. For more information, see `Amazon S3 Bucket Policy for Compute Optimizer <https://docs.aws.amazon.com/compute-optimizer/latest/ug/create-s3-bucket-policy-for-compute-optimizer.html>`__ in the *Compute Optimizer User Guide*.

    

  
    - **bucket** *(string) --* 

      The name of the Amazon S3 bucket to use as the destination for an export job.

      

    
    - **keyPrefix** *(string) --* 

      The Amazon S3 bucket prefix for an export job.

      

    
  
  :type fileFormat: string
  :param fileFormat: 

    The format of the export file.

     

    The only export file format currently supported is ``Csv``.

    

  
  :type includeMemberAccounts: boolean
  :param includeMemberAccounts: 

    Indicates whether to include recommendations for resources in all member accounts of the organization if your account is the management account of an organization.

     

    The member accounts must also be opted in to Compute Optimizer, and trusted access for Compute Optimizer must be enabled in the organization account. For more information, see `Compute Optimizer and Amazon Web Services Organizations trusted access <https://docs.aws.amazon.com/compute-optimizer/latest/ug/security-iam.html#trusted-service-access>`__ in the *Compute Optimizer User Guide*.

     

    Recommendations for member accounts of the organization are not included in the export file if this parameter is omitted.

     

    This parameter cannot be specified together with the account IDs parameter. The parameters are mutually exclusive.

     

    Recommendations for member accounts are not included in the export if this parameter, or the account IDs parameter, is omitted.

    

  
  :type recommendationPreferences: dict
  :param recommendationPreferences: 

    An object to specify the preferences for the Amazon EC2 Auto Scaling group recommendations to export.

    

  
    - **cpuVendorArchitectures** *(list) --* 

      Specifies the CPU vendor and architecture for Amazon EC2 instance and Amazon EC2 Auto Scaling group recommendations.

       

      For example, when you specify ``AWS_ARM64`` with:

       

      
      * A  GetEC2InstanceRecommendations or  GetAutoScalingGroupRecommendations request, Compute Optimizer returns recommendations that consist of Graviton instance types only.
       
      * A  GetEC2RecommendationProjectedMetrics request, Compute Optimizer returns projected utilization metrics for Graviton instance type recommendations only.
       
      * A  ExportEC2InstanceRecommendations or  ExportAutoScalingGroupRecommendations request, Compute Optimizer exports recommendations that consist of Graviton instance types only.
      

      

    
      - *(string) --* 

      
  
  
  
  :rtype: dict
  :returns: 
    
    **Response Syntax**

    
    ::

      {
          'jobId': 'string',
          's3Destination': {
              'bucket': 'string',
              'key': 'string',
              'metadataKey': 'string'
          }
      }
      
    **Response Structure**

    

    - *(dict) --* 
      

      - **jobId** *(string) --* 

        The identification number of the export job.

         

        Use the  DescribeRecommendationExportJobs action, and specify the job ID to view the status of an export job.

        
      

      - **s3Destination** *(dict) --* 

        An object that describes the destination Amazon S3 bucket of a recommendations export file.

        
        

        - **bucket** *(string) --* 

          The name of the Amazon S3 bucket used as the destination of an export file.

          
        

        - **key** *(string) --* 

          The Amazon S3 bucket key of an export file.

           

          The key uniquely identifies the object, or export file, in the S3 bucket.

          
        

        - **metadataKey** *(string) --* 

          The Amazon S3 bucket key of a metadata file.

           

          The key uniquely identifies the object, or metadata file, in the S3 bucket.

          
    
  
  **Exceptions**
  
  *   :py:class:`ComputeOptimizer.Client.exceptions.OptInRequiredException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.InternalServerException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.ServiceUnavailableException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.AccessDeniedException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.InvalidParameterValueException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.MissingAuthenticationToken`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.ThrottlingException`

  
  *   :py:class:`ComputeOptimizer.Client.exceptions.LimitExceededException`

  