What is Elastic Load Balancing?
Elastic Load Balancing automatically distributes your incoming traffic across multiple targets, such as EC2 instances, containers, and IP addresses, in one or more Availability Zones. It monitors the health of its registered targets, and routes traffic only to the healthy targets. Elastic Load Balancing scales your load balancer capacity automatically in response to changes in incoming traffic.
Load balancer benefits
A load balancer distributes workloads across multiple compute resources, such as virtual servers. Using a load balancer increases the availability and fault tolerance of your applications.
You can add and remove compute resources from your load balancer as your needs change, without disrupting the overall flow of requests to your applications.
You can configure health checks, which monitor the health of the compute resources, so that the load balancer sends requests only to the healthy ones. You can also offload the work of encryption and decryption to your load balancer so that your compute resources can focus on their main work.
Features of Elastic Load Balancing
Elastic Load Balancing supports multiple load balancer types. You can select the type of load balancer that best suits your needs. .
For more information about the current generation load balancers, see the following documentation:
Classic Load Balancers are the previous generation of load balancers from Elastic Load Balancing. We recommend that you migrate to a current generation load balancer. For more information, see Migrate your Classic Load Balancer.
Accessing Elastic Load Balancing
You can create, access, and manage your load balancers using any of the following interfaces:
- 
                Amazon Web Services Management Console— Provides a web interface that you can use to access Elastic Load Balancing. 
- 
                Amazon Command Line Interface (Amazon CLI) — Provides commands for a broad set of Amazon services, including Elastic Load Balancing. The Amazon CLI is supported on Windows, macOS, and Linux. For more information, see Amazon Command Line Interface . 
- 
                Amazon SDKs — Provide language-specific APIs and take care of many of the connection details, such as calculating signatures, handling request retries, and error handling. For more information, see Amazon SDKs . 
- 
                Query API— Provides low-level API actions that you call using HTTPS requests. Using the Query API is the most direct way to access Elastic Load Balancing. However, the Query API requires that your application handle low-level details such as generating the hash to sign the request, and error handling. For more information, see the following: - 
                        Application Load Balancers, Network Load Balancers, and Gateway Load Balancers — API version 2015-12-01 
- 
                        Classic Load Balancers — API version 2012-06-01 
 
- 
                        
Related services
Elastic Load Balancing works with the following services to improve the availability and scalability of your applications.
- 
                Amazon EC2 — Virtual servers that run your applications in the cloud. You can configure your load balancer to route traffic to your EC2 instances. For more information, see the Amazon EC2 User Guide. 
- 
                Amazon EC2 Auto Scaling — Ensures that you are running your desired number of instances, even if an instance fails. Amazon EC2 Auto Scaling also enables you to automatically increase or decrease the number of instances as the demand on your instances changes. If you enable Auto Scaling with Elastic Load Balancing, instances that are launched by Auto Scaling are automatically registered with the load balancer. Likewise, instances that are terminated by Auto Scaling are automatically de-registered from the load balancer. For more information, see the Amazon EC2 Auto Scaling User Guide. 
- 
                Amazon Certificate Manager — When you create an HTTPS listener, you can specify certificates provided by ACM. The load balancer uses certificates to terminate connections and decrypt requests from clients. 
- 
                Amazon CloudWatch — Enables you to monitor your load balancer and to take action as needed. For more information, see the Amazon CloudWatch User Guide. 
- 
                Amazon ECS — Enables you to run, stop, and manage Docker containers on a cluster of EC2 instances. You can configure your load balancer to route traffic to your containers. For more information, see the Amazon Elastic Container Service Developer Guide. 
- 
                Amazon Global Accelerator — Improves the availability and performance of your application. Use an accelerator to distribute traffic across multiple load balancers in one or more Amazon Regions. For more information, see the Amazon Global Accelerator Developer Guide. 
- 
                Route 53 — Provides a reliable and cost-effective way to route visitors to websites by translating domain names into the numeric IP addresses that computers use to connect to each other. For example, it would translate www.example.cominto the numeric IP address192.0.2.1. Amazon assigns URLs to your resources, such as load balancers. However, you might want a URL that is easy for users to remember. For example, you can map your domain name to a load balancer. For more information, see the Amazon Route 53 Developer Guide.
- 
                Amazon WAF — You can use Amazon WAF with your Application Load Balancer to allow or block requests based on the rules in a web access control list (web ACL). For more information, see the Amazon WAF Developer Guide. 
Pricing
With your load balancer, you pay only for what you use. For more information, see 
            Elastic Load Balancing pricing