Back to Aws Doc Sdk Examples

Auto Scaling code examples for the SDK for Python

python/example_code/auto-scaling/README.md

latest6.0 KB
Original Source

Auto Scaling code examples for the SDK for Python

Overview

Shows how to use the AWS SDK for Python (Boto3) to work with Amazon EC2 Auto Scaling.

<!--custom.overview.start--> <!--custom.overview.end-->

Auto Scaling automatically scales EC2 instances, either with scaling policies or with scheduled scaling.

⚠ Important

  • Running this code might result in charges to your AWS account. For more details, see AWS Pricing and Free Tier.
  • Running the tests might result in charges to your AWS account.
  • We recommend that you grant your code least privilege. At most, grant only the minimum permissions required to perform the task. For more information, see Grant least privilege.
  • This code is not tested in every AWS Region. For more information, see AWS Regional Services.
<!--custom.important.start--> <!--custom.important.end-->

Code examples

Prerequisites

For prerequisites, see the README in the python folder.

Install the packages required by these examples by running the following in a virtual environment:

python -m pip install -r requirements.txt
<!--custom.prerequisites.start--> <!--custom.prerequisites.end-->

Get started

Basics

Code examples that show you how to perform the essential operations within a service.

Single actions

Code excerpts that show you how to call individual service functions.

Scenarios

Code examples that show you how to accomplish a specific task by calling multiple functions within the same service.

<!--custom.examples.start--> <!--custom.examples.end-->

Run the examples

Instructions

<!--custom.instructions.start--> <!--custom.instructions.end-->

Hello Auto Scaling

This example shows you how to get started using Auto Scaling.

python hello/hello_autoscaling.py

Learn the basics

This example shows you how to do the following:

  • Create an Amazon EC2 Auto Scaling group with a launch template and Availability Zones, and get information about running instances.
  • Enable Amazon CloudWatch metrics collection.
  • Update the group's desired capacity and wait for an instance to start.
  • Terminate an instance in the group.
  • List scaling activities that occur in response to user requests and capacity changes.
  • Get statistics for CloudWatch metrics, then clean up resources.
<!--custom.basic_prereqs.auto-scaling_Scenario_GroupsAndInstances.start--> <!--custom.basic_prereqs.auto-scaling_Scenario_GroupsAndInstances.end-->

Start the example by running the following at a command prompt:

python scenario_groups_and_instances.py
<!--custom.basics.auto-scaling_Scenario_GroupsAndInstances.start--> <!--custom.basics.auto-scaling_Scenario_GroupsAndInstances.end-->

Build and manage a resilient service

This example shows you how to create a load-balanced web service that returns book, movie, and song recommendations. The example shows how the service responds to failures, and how to restructure the service for more resilience when failures occur.

  • Use an Amazon EC2 Auto Scaling group to create Amazon Elastic Compute Cloud (Amazon EC2) instances based on a launch template and to keep the number of instances in a specified range.
  • Handle and distribute HTTP requests with Elastic Load Balancing.
  • Monitor the health of instances in an Auto Scaling group and forward requests only to healthy instances.
  • Run a Python web server on each EC2 instance to handle HTTP requests. The web server responds with recommendations and health checks.
  • Simulate a recommendation service with an Amazon DynamoDB table.
  • Control web server response to requests and health checks by updating AWS Systems Manager parameters.
<!--custom.scenario_prereqs.cross_ResilientService.start--> <!--custom.scenario_prereqs.cross_ResilientService.end-->

Start the example by running the following at a command prompt:

python ../../cross_service/resilient_service/runner.py
<!--custom.scenarios.cross_ResilientService.start-->

Complete details and instructions on how to run this example can be found in the README for the example.

<!--custom.scenarios.cross_ResilientService.end-->

Tests

⚠ Running tests might result in charges to your AWS account.

To find instructions for running these tests, see the README in the python folder.

<!--custom.tests.start--> <!--custom.tests.end-->

Additional resources

<!--custom.resources.start--> <!--custom.resources.end-->

Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.

SPDX-License-Identifier: Apache-2.0