- It is a high-level deployment tool
- Helps you get an app from desktop to web in a matter of minutes.
- handles details of hosting environment for
- capacity provisioning
- load balancing
- scaling
- application health monitoring
- A platform configuration defines infrastructure and software stack to be used for a given environment.
- When you deploy app, Elastic Beanstalk provisions a set of AWS resources
- AWS resources can include Amazon EC2 instances, alarms, a load balancer, security groups, and more.
Using Beanstalk
- First create an application
- upload an application version in form of an application source bundle (for example, a Java .war file) to Elastic Beanstalk
- then, provide some information about application.
- Elastic Beanstalk automatically launches an environment and creates and configures AWS resources needed to run code.
- After environment is launched, you can then manage environment and deploy new application versions.
Following diagram illustrates workflow of Elastic Beanstalk.
data:image/s3,"s3://crabby-images/2e8a4/2e8a4618800740faa20bffe3a54043e087ca2a15" alt=""
After creating and deploying application, information about application—including metrics, events, and environment status, is available through
- AWS Management Console, APIs
- Command Line Interfaces and
- unified AWS CLI
Beanstalk Terms
Application
- It is a logical collection of Elastic Beanstalk components
- includes
- environments
- versions
- environment configurations.
- application is similar to a folder.
Application Version
- It is a specific, labeled iteration of deployable code for a web application.
- It points to S3 object having deployable code like a Java WAR file.
- It is part of an application.
- Applications can have multiple versions
- Each application version is unique.
- In a running environment, deploy any application version
Environment
- It is a collection of AWS resources running an application version.
- It runs only one application version at a time
- Same or different application versions can run in many environments simultaneously.
- After creating environment, Elastic Beanstalk provisions resources needed to run application version.
Environment Tier
- It designates type of application that environment runs
- It determines what resources Elastic Beanstalk provisions to support it.
- An application serving HTTP requests runs in a web server environment tier.
- It is to be selected if launching an Elastic Beanstalk environment
Environment Configuration
- Identifies parameters and settings which define behavior of environment and its resources.
- If environment’s configuration settings are changed, Elastic Beanstalk automatically applies changes to existing resources
Saved Configuration
- It is a template to be used as a starting point for creating unique environment configurations.
- Can create and modify saved configurations
- Apply saved configurations to environments
by
- Elastic Beanstalk console
- EB CLI
- AWS CLI or API.
- API and AWS CLI refer to saved configurations as configuration templates.
Platform
- It is a combination of
- operating system
- programming language runtime
- web server
- application server
- Elastic Beanstalk components.
Web Server Environments
Sample web server environment tier, and their working
data:image/s3,"s3://crabby-images/010e7/010e742ef0381b16ae49a8a10ffdd11656f601a0" alt=""
Worker Environments
AWS resources created for a worker environment tier include
- Auto Scaling group,
- one or more Amazon EC2 instances
- an IAM role.
- SQS queue
- Elastic Beanstalk installs required files for programming language
- daemon also runs on each EC2 instance in Auto Scaling group to read messages from SQS queue
Components and their interactions
data:image/s3,"s3://crabby-images/24558/245585a10d370d701bb5d375be781a426c65d51f" alt=""
- Reliable, scalable, hosted queue service for sending, storing and retrieving messages.
- Queue act as a buffer between sender and receiver.
- 256kb message, >256kb managed using SQS extended client library which uses S3, deliver message atleast once, not FIFO, can be create in
- any region, retained for 14 days
- can be sent and read simultaneously
- long polling reduces frequent polling (wait 20 secs if queue empty)
- First 1 million request free, $0.50 next 1 million + data transfer charges, SQS queues can be scaled.
- Amazon SQS Architectures
- Priority (2 queues High/Low)
- Fanout (SNS topic/multiple SQS queues for parallel processing)
- Amazon SQS supports both standard and FIFO queues.
- Standard
Queue
- Unlimited Throughput
- At-Least-Once Delivery
- Best-Effort Ordering
- FIFO
Queue
- High Throughput
- Exactly-Once Processing
- First-In-First-Out Delivery
Distributed Queues
3 parts in a distributed messaging system
- components of distributed system
- queue (distributed on Amazon SQS servers),
- messages in queue.
Below, system send messages to queue and receive messages from queue. queue (holds messages A through E) redundantly stores messages across multiple Amazon SQS servers.
data:image/s3,"s3://crabby-images/2526a/2526a0ee6d9e2deac0187c4e4348708d79452829" alt=""
Message Lifecycle
data:image/s3,"s3://crabby-images/c6930/c69307aa3b1c3c64d81b474a798d957295f90503" alt=""
- A producer or component 1 sends message A to a queue, and message is distributed across Amazon SQS servers redundantly.
- When a consumer or component 2 is ready to process messages, it consumes messages from queue, and message A is returned. While message A is being processed, it remains in queue and isn’t returned to subsequent receive requests for duration of visibility timeout.
- consumer or component 2 deletes message A from queue to prevent message from being received and processed again when visibility timeout expires.
Best Practices
- Processing Messages in a Timely Manner
- Handling Request Errors
- Setting Up Long Polling
- Capturing Problematic Messages
- Setting Up Dead-Letter Queue Retention
- Avoiding Inconsistent Message Processing
- Implementing Request-Response Systems
To reduce costs, batch message actions:
- use Amazon SQS batch API actions
- use long polling together with buffered asynchronous client.