KEMBAR78
AWS Dev Part1 | PDF | Cloud Computing | Software As A Service
0% found this document useful (0 votes)
328 views178 pages

AWS Dev Part1

This document provides an overview of cloud computing and Amazon Web Services (AWS). It defines various cloud computing models including Infrastructure as a Service (IaaS), Platform as a Service (PaaS), Software as a Service (SaaS), Storage as a Service (STaaS), Data as a Service (DaaS), and Function as a Service (FaaS). It describes the benefits of cloud computing such as cost savings, global scale, speed, security and performance. It also provides examples of AWS services that fall under each cloud computing model.

Uploaded by

Spicyz Trickz
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
328 views178 pages

AWS Dev Part1

This document provides an overview of cloud computing and Amazon Web Services (AWS). It defines various cloud computing models including Infrastructure as a Service (IaaS), Platform as a Service (PaaS), Software as a Service (SaaS), Storage as a Service (STaaS), Data as a Service (DaaS), and Function as a Service (FaaS). It describes the benefits of cloud computing such as cost savings, global scale, speed, security and performance. It also provides examples of AWS services that fall under each cloud computing model.

Uploaded by

Spicyz Trickz
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 178

PART I

Getting Started on the AWS


Journey

■ Chapter 1 Overview of Cloud Computing and AWS


■ Chapter 2 Interacting with AWS Using API, SDK, and CLI
■ Chapter 3 Networking Using Amazon Virtual Private Cloud
■ Chapter 4 Creating a Virtual Machine Using Amazon EC2
CHAPTER 1

Overview of Cloud Computing and


AWS
In this chapter, you will learn
• Cloud computing overview
• Benefits of cloud computing
• Cloud deployment models: IaaS, STaaS, PaaS, DaaS, FaaS, and SaaS
• Cloud services types: public, private, hybrid, and community
• AWS history
• AWS regions and availability zones (AZs)
• AWS services
• AWS in action

Congratulations on purchasing this All-in-One Exam Guide! You are one step
closer to learning how to build applications for the cloud. I am excited to
join you on this journey toward developing cloud native applications for
Amazon Web Services (AWS) and of course becoming an AWS-certified
developer associate. You will learn everything you need to create, automate,
migrate, and monitor applications in the AWS cloud.

Cloud Computing Overview


Cloud computing is the on-demand delivery of computing resources, such as
servers, storage, networking, databases, and other services, over the Internet.
Its pay-as-you-go pricing means that you pay only for the services you use,
which reduces or eliminates your organization’s total cost of ownership and
lowers operating costs. Cloud computing enables you to run your
infrastructure more efficiently: it enables faster business innovation, offers
flexibility to scale as your business needs change, and helps create
economies of scale.

Cloud Computing Benefits


Cloud computing creates a major shift from the traditional methods used to
access IT resources in organizations. Here are few basic benefits of
migrating to cloud computing services:
• Global scale Cloud computing enables you to deploy your IT
infrastructure in other parts of the world quickly and easily. Suppose, for
example, you operate a chain of successful stores in the United States
and want to expand your business to other countries across the globe.
Using traditional IT methods, this could take a few months to a year,
based on the size and complexity required to build datacenters in those
countries for operation. In contrast, if you use a public cloud provider
such as AWS, you can deploy similar infrastructures in different
countries or continents within a few hours. You can even set up a global
disaster recovery system with only few mouse clicks.
• Cost Cloud computing reduces or eliminates the costs of purchasing
server hardware and software; setting up datacenters; providing power
supplies, cooling, and security; and hiring IT experts to manage your
infrastructure. Suppose your startup company creates and markets a big
data analytical solution that handles petabytes of data. With a traditional
IT infrastructure and on-premises datacenter, this could require upfront
costs of $200,000 to $300,000. Using cloud computing, however, you
simply create an account with AWS and start building your
infrastructure; then you can scale up or down as needed and pay for only
the services you actually use.
• Speed In a traditional onsite infrastructure, capacity planning for each
IT resource takes much time and effort. In AWS cloud computing, you
can provision IT services on demand and within few minutes using the
AWS self-service portal. You can also use automated scripts to
provision a complex infrastructure quickly in different regions and scale
it up or down to accommodate demand.
• Security You are responsible for the end-to-end security in a
traditional on-premises datacenter, where the disconnected security and
monitoring tools used by the many teams that manage different
infrastructures can make security management difficult. In cloud
computing, security tools are interconnected and mostly driven by the
developer. The cloud’s shared security model can help relieve some of
the organization’s security responsibilities.
• Performance The top cloud computing providers use high-speed
networks to provide secure datacenters around the world in different
regions and continents. These providers regularly upgrade their
infrastructures with the latest generation of fast and efficient hardware
and software. This offers great advantages over running your workload
on a single corporate datacenter, including reduced latency for
applications and global content delivery systems.

Cloud Deployment Models: IaaS, STaaS, PaaS, DaaS, FaaS,


SaaS
Cloud deployment models represent a specific, prepackaged stack of various
types of services. Figure 1-1 shows the IT resources that are managed by
cloud vendors based on their cloud deployment model offerings. The
following sections are descriptions of each of the deployment models.
Figure 1-1 Cloud deployment models and the IT resources provided

Infrastructure as a Service (IaaS)


IaaS provides virtualized computing resources over the Internet, such as
virtual servers with scalable CPU, memory, storage, network, security, and
more. With IaaS, customers don’t need to manage or control the physical
cloud framework; however, customers have full control over the operating
systems, storage, and applications they deploy. Because the IaaS customer
doesn’t need its own physical datacenters, it can use IaaS as a fast,
disposable, cheap infrastructure that can be expanded or terminated
according to business requirements. If you are traditional organization on a
tight budget, IaaS is a good choice, because you pay only for the services you
use. The most popular cloud platforms that offer IaaS are Amazon Elastic
Compute Cloud (Amazon EC2), Azure Virtual Machines, and Google
Compute Engine, along with open source alternatives OpenStack and Apache
CloudStack. (For more information, see
https://www.g2.com/categories/infrastructure-as-a-service-iaas.)

Storage as a Service (STaaS)


With STaaS, a platform such as AWS offers its storage infrastructure (in
AWS, it’s Amazon Simple Storage Service, or S3) to another organization or
individual to store files, objects, and backup data. Organizations and
individuals find this very convenient, because they don’t need to manage the
underlying storage infrastructure, which is highly available. STaaS works
through a web-based application programming interface (API) that is
remotely implemented through its interaction with the customer’s on-
premises applications and the provider’s cloud storage infrastructure. If the
organization ever loses its local data, it can be retrieved from the cloud
storage. STaaS could be used as disaster recovery storage for an on-
premises application infrastructure. The most popular enterprise-level cloud
storage platforms are Amazon S3, Google Cloud Storage, and Microsoft
Azure Storage, along with popular open source alternatives ownCloud and
Cozy Cloud.

Platform as a Service (PaaS)


PaaS offers tools and services to help customers develop and deploy
applications rapidly and efficiently. A PaaS cloud provider hosts and
maintains the hardware and software for you. This helps your developers
spend more time doing what they do best, developing solutions, rather than
spending time installing and managing the hardware and software required to
develop or run new applications. PaaS providers manage and control the
underlying cloud infrastructure, including network, servers, operating
systems, and storage, while cloud consumers control the deployed
applications as well as configuration settings for the application-hosting
environment. The most popular examples of PaaS platforms are AWS
Lambda, AWS Elastic Beanstalk, Google App Engine, and Microsoft Azure
App Service, along with open source alternatives such as Red Hat
OpenShift, OpenPaaS, and Cloud Foundry.

Data as a Service (DaaS)


DaaS is a more advanced, fine-grained form of SaaS, in which data (as
opposed to files) is readily accessible through a cloud-based system. Data in
the form of databases or object containers is supplied on demand via cloud
platforms. The DaaS cloud vendor provides tools that make it easier to
access and explore the data, regardless of the user’s geographical location or
organizational separation. This offers a number of significant opportunities.
DaaS eliminates the single point of failure by providing redundancy and
makes the data available for multiple users using different database tools.
Popular enterprise-level DaaS database platforms are Amazon DynamoDB,
Microsoft Azure Cosmos DB, and Google Cloud Datastore, along with open
source alternatives such as Apache Cassandra, CockroachDB, and Apache
CouchDB.

Function as a Service (FaaS)


The idea of running serverless computing is behind FaaS, which means
customers don’t have to provision or scale their servers. As a developer, you
run a piece of business logic or deploy an individual function without
worrying about the underlying infrastructure. The function will start executing
your business logic within a few milliseconds, and after successful
completion, it terminates the infrastructure in the background. The functions
are event driven and scalable instantaneously in the background. FaaS
completely abstracts the servers away from developers, and customers are
billed based on their consumption and number of executions. FaaS is
extremely popular among developers and was introduced by hook.io in 2014,
followed by AWS Lambda, Google Cloud Functions, and Microsoft Azure
Functions, with open source alternatives OpenWhisk and Fn project
Functions.

Software as a Service (SaaS)


If you use e-mail, you are using SaaS. The vendor manages everything from
the infrastructure side, and access to the applications is provided on a
subscription basis, via a web browser, programming interface, or mobile
platform. You don’t have to install any software with SaaS, and SaaS lets you
access software from any device via the Internet, from any place, at any time.
Installation, maintenance, security, and compliance are managed by the SaaS
provider. The cloud giants AWS, Azure, Google Cloud, and many others
offer SaaS services. Popular SaaS products include Google G Suite,
Microsoft Office 365, and Slack.

Cloud Services Types: Public, Private, Hybrid, and


Community
The cloud has increasingly become a default platform for developers. Cloud
computing resources are built to provide abstraction from the management,
architecting, and scaling requirements of a core infrastructure. Cloud-native
applications are fully deployed on the cloud, and all related application
services are running in the cloud.
Four popular cloud service types vary significantly based on how the
services are offered and by whom: the public cloud, private cloud, hybrid
cloud, and community cloud.

Public Cloud
In the public cloud, resources such as servers, databases, storage, and
networking are owned and operated by third-party cloud service vendors and
delivered through the Internet. All the hardware, software, and other
supporting infrastructure is owned and managed by the cloud vendor. Each
customer organization shares the same hardware, storage, and network
devices with other customer organizations, or cloud tenants. As a customer,
you can access the cloud services and manage your account using a web
browser. You don’t need to purchase hardware or software, and you pay only
for the services you use. Your cloud vendor provides the maintenance and
enables you to scale on-demand to meet your business needs. The public
clouds are usually built on massive hardware installations distributed in
different locations throughout the country or across the globe. Their size
enables economies of scale, which allows for maximum scalability to meet
company requirements to expand or contract and to meet surges in demand in
real time, and provides maximum reliability in case of hardware failures.

Private Cloud
In a private cloud, computing resources are used exclusively by one business
or organization. The entire infrastructure is physically located at your
organization’s on-premises datacenter, or it’s hosted by a third-party service
provider. In a private cloud, the entire IT infrastructure is maintained within
a private network and not shared with anyone. All the hardware and software
are dedicated exclusively to your organization. A private cloud makes it
easier for an organization to customize its infrastructure resources to meet
specific IT and business requirements. Financial institutions, government
agencies, and other midsize to large enterprises with business-critical
operations use private clouds, which offer full control and security over their
infrastructure environment. In a private cloud, the infrastructure sits behind
your company firewall, which is accessed only through an intranet via
encrypted connections. Private clouds provide enhanced levels of security
and privacy since the entire IT infrastructure is dedicated to a single client.
Private clouds are more expensive to install, maintain, and operate than
public clouds, and organizations are limited to using only the current
infrastructure unless they procure, install, and configure a new infrastructure
to meet demands.

Community Cloud
A community cloud is similar to a private cloud, but it provides a cloud
solution for particular business communities, such as banks or trading
companies. The members of the community cloud share similar security,
compliance, privacy, and performance requirements. Community cloud
members normally own private cloud space that is built to meet the security,
privacy, and compliance needs that are common in the community.
Organizations involved in financial, health, and legal activities require
community clouds that adhere to strict regulatory requirements. The
community cloud service provider often combines different types of clouds
with different service models to provide businesses with attractive cloud
solutions to meet organization requirements.

Hybrid Cloud
The hybrid cloud offers the best of both worlds; it combines on-premises
infrastructure with public and community clouds so organizations can reap
the advantages of all three. It provides a way to secure sensitive data that
remains within the private cloud, where high security standards can be
maintained. Applications that do not contain sensitive data or that are not
bound by compliance requirements use the public cloud, where infrastructure
can be scaled to meet demands at a reduced cost. Hybrid clouds are most
suited for running big data operations on nonsensitive data in the public
cloud, while keeping sensitive data secured in the private cloud. In a hybrid
cloud, it is easy to migrate the data and applications between private and
public clouds for greater flexibility and more deployment options.

AWS History
Amazon Web Services (AWS), one of the world’s most popular cloud
computing platforms, emerged as a side business of Amazon.com in the early
2000s to help developers deal with the burgeoning growth of the company’s
online presence and to improve the efficiency of Amazon’s own
infrastructure. The beginnings of AWS as a development tool can be traced
back to 2002, when an underlying beta was released that offered SOAP and
XML interfaces for the Amazon product inventory database. It provided an
amazing platform for developers and was the first step by Amazon in
grasping the capability of developer-friendly tools, especially in an
infrastructure area, as an actual cloud product.

NOTE For more on AWS history, see


https://www6.software.ibm.com/developerworks/education/ws-aws1/ws-
aws1-ltr.pdf.

In 2003, Amazon leadership brainstormed to identify the company’s top


qualities to differentiate the company from the other similar organizations.
One thing was abundantly clear: its infrastructure service—now known as
AWS—gave the company an enormous advantage over its competition.
From that point, a more remarkable idea arose to blend an infrastructure
framework and development tools to create a pseudo-operating system
framework that could be used over the Internet. The infrastructure framework
was separated into different components, such as compute, storage, and
database, and could be managed using a variety of developer tools.
Amazon’s first acknowledgment of AWS was in a blog entry of AWS Chief
Evangelist Jeff Barr in 2004, alluding to the development of AWS cloud
computing.
AWS launched Amazon Simple Storage Service (S3) and Amazon Elastic
Compute Cloud (EC2) along with Amazon Simple Queue Service (SQS) on
March 19, 2006. Amazon launched S3 and EC2 services in Europe in 2009.
Along with the Amazon Elastic Block Store (EBS), the Amazon CloudFront
content delivery network (CDN) became part of its formal AWS offerings.
These developer-friendly services attracted enterprises such as Dropbox,
Netflix, and Reddit along with all the cloud-ready customers in 2010 as early
adopters. AWS continued innovating and spreading its footprint, attracting
organizations from across the globe.

AWS Regions and Availability Zones


AWS serves more than a million dynamic customers in more than 190
nations. AWS continues to grow worldwide to enable its clients to
accomplish lower latency and higher performance, and to guarantee that
client data lives only in the AWS region the client designates. AWS helps
organizations build their initial infrastructures and continually provides the
scalable infrastructure that meets clients’ requirements worldwide.
The AWS cloud infrastructure is connected globally and isolated as AWS
regions and availability zones (AZs). An AWS region includes numerous
AZs, each of which comprises one or more separate datacenters, each with
redundant power, networking, and connectivity, and isolated in a separate
location. As shown in Figure 1-2, AZs provide the infrastructure that enables
organizations to create enterprise applications and databases that are more
highly available, fault-tolerant, and scalable than what is possible with
single, on-premises customer datacenters. As of June 2020, the AWS cloud
covers 76 AZs in 24 geographically separate regions around the globe, with
more regions and zones planned on the horizon. Please refer to
https://aws.amazon.com/about-aws/global-infrastructure/?p=ngi&loc=0 for
the latest information about regions and AZs.
Figure 1-2 Availability zone

Each Amazon region is totally separate from others, as demonstrated in


Figure 1-3. This accomplishes the best options for dependability and to
reduce critical failure issues. Although every AZ is segregated, AZs within a
region are associated through low-latency links. This enables AWS to
provide the flexibility for organizations to create instances and store data
inside different geographic regions as well as over numerous AZs within a
particular AWS region. Each AWS AZs are designed to prevent independent
failure, which reduces the potential risk of a single point of failure.
Figure 1-3 Availability zones within an AWS region can be associated with
low-latency links

AWS Services
AWS offers a variety of global cloud-based products, as shown in the
following table, that provide for compute, database, storage, networking,
security, management tools, mobile, developer tools, analytics, and Internet
of Things (IoT). Millions of customers, from large enterprises, to fast-
growing startups, to leading government agencies, trust AWS to host their
workloads and help them become more agile. AWS services help
organizations to move to the cloud more quickly, at lower IT costs and scale.
AWS in Action
Let’s now jump into action to showcase the capabilities of AWS. You will be
building similar architectures on AWS in later chapters, where I will help
you with step-by-step instructions. For this example, assume you have an e-
commerce website in a traditional datacenter, as shown in Figure 1-4.
Figure 1-4 Traditional e-commerce infrastructure

Your company has decided to migrate to AWS without making any


modifications to the web application and database. If this e-commerce
application is moved to AWS as lift and shift without any changes, your AWS
e-commerce infrastructure will look similar to that shown in Figure 1-5. The
traditional web server will be replaced by an AWS EC2 instance, and your
traditional database will be replaced by Amazon RDS in an AWS AZ of your
choice.
Figure 1-5 AWS e-commerce infrastructure

As your e-commerce website becomes more popular, you’ll need to scale


your infrastructure to accommodate the increased flow of traffic from all
over the world, 24 hours a day, without any interruption. If you were still
using a traditional on-premises infrastructure, it would take weeks to months
to scale up. But because you’ve migrated the infrastructure to AWS, scaling
up will be simple: you’ll add a few more services manually via the AWS
Management Console or use AWS CloudFormation to automate the
infrastructure creation. Your scaled up infrastructure will look similar to
Figure 1-6.
Figure 1-6 AWS e-commerce high-availability infrastructure

Now your e-commerce site has both dynamic content, such as products
and price, and static content, such as images and videos. Separating the
dynamic and static content will reduce the load and latency and improve
performance by delivering the static contents from the AWS content delivery
network, CloudFront. The workload will be shared by multiple smaller
virtual machines behind an application load balancer. If one of the virtual
machine fails, you’ll use Amazon Elastic Load Balancing (ELB) to send the
customer traffic to other running virtual machines, which improves
reliability.
EC2 Auto Scaling will add a new instance to replace any failed instance
and will add more instances automatically when traffic increases during a
peak period. The RDS database instances will automatically failover to
secondary instances if your primary database instance fails in a multi-AZ
deployment. In addition, the Amazon RDS Read Replica will run all your
read-only queries and reports. All of this can be configured and achieved in
hours in AWS, versus weeks to months in a traditional datacenter
environment.

Chapter Review
This chapter introduced and covered the benefits of cloud computing, along
with various well-known cloud deployment models: Infrastructure as a
Service (IaaS), Storage as a Service (STaaS), Platform as a Service (PaaS),
Data as a Service (DaaS), Function as a Service (FaaS), and Software as a
Service (SaaS). It also explained cloud services types—public, private,
community, and hybrid—and offered a brief history of AWS, including how
AWS started as an Amazon developer tool. I introduced you to various AWS
regions and availability zones and discussed isolation techniques.
You were briefly introduced to each AWS service. It’s crucial that you
understand these—you should at least be familiar with what each service
offers, to help you build highly available, highly scalable, and fault-tolerant
applications in AWS.
Finally, you saw AWS in action. I demonstrated how easy it is to migrate
your workload from an on-premises infrastructure to the AWS cloud and
quickly scale that infrastructure. You may feel a bit overwhelmed at this
point, but in subsequent chapters I’ll provide practical and easy-to-follow
information.
In addition to earning your AWS Certified Developer – Associate
certification, you will be building secure, cloud-native applications on the
AWS cloud. Let’s begin the journey together. As the famous Chinese proverb
says, “A journey of a thousand miles begins with a single step.”

Questions
The following questions will help you gauge your understanding of the
contents in this chapter. Read all the answers carefully because there might
be more than one correct answer. Choose the best response for each question.

1. A traditional three-tier architecture comprises which of the following


tiers? (Choose three.)
A. Security tier
B. Application tier
C. Web tier
D. Database tier
2. An AWS region comprises two or more physical locations that provide
high availability and fault tolerance for your applications. Those
physical locations are called what?
A. Cloud datacenters
B. Edge locations
C. Availability zones
D. DMZ zones
3. You want to deploy your applications and databases in a logically
isolated section of the AWS cloud. Which AWS service provides you an
isolated networking layer?
A. Regions
B. Amazon Route 53
C. Amazon VPC
D. Availability zones
4. You want to host a static website, and you don’t want to manage any
servers. Which of the following services will help you achieve this?
A. AWS Lambda
B. Amazon EC2
C. Amazon OpsWorks
D. Amazon S3
5. You want to monitor your EC2 instances for CPU utilization and
memory and visualize the health of the server using a dashboard. Which
of the following AWS services could be used for this case?
A. Amazon OpsWorks
B. Amazon CloudWatch
C. AWS CloudTrial
D. Amazon VPC Flowlogs
6. You want to scale your current EC2 servers and you do not want to
manage the scaling manually. Which AWS service will detect when an
instance is unhealthy, terminate it, and replace it with a new one?
A. Amazon EC2 Auto Scaling
B. Amazon Route 53
C. Amazon CloudWatch
D. Amazon Elastic Load Balancing
7. You have been storing your data in Amazon S3, and you are required to
query the data without moving it to a database using ANSI SQL. Which
AWS service enables you to quickly query the data stored in S3?
A. Amazon EMR
B. Amazon Simple Queue Service
C. Amazon Athena
D. Amazon Neptune
8. Your company needs a service that lets you run code without
provisioning or managing servers. To save costs, the company doesn’t
want to pay for infrastructure in an idle state. Which of the following
services could you use for this scenario?
A. AWS Lambda
B. Amazon EC2
C. AWS Fargate
D. Amazon Lightsail
9. You want to migrate your relational database to AWS, but you don’t
want to perform the time-consuming administration tasks such as
database installation, patching, and backups. Which of the following
will meet your needs?
A. AWS Fargate
B. Amazon RDS
C. Amazon S3
D. Amazon Athena
10. Your gaming application is a data-intensive application and requires
high throughput and low latency for gamers who access your
application. Which AWS service provides support for an in-memory
database?
A. Amazon EC2
B. Amazon RDS
C. Amazon S3
D. Amazon ElastiCache
11. In your global enterprise, applications are running in different countries,
and you want to route traffic to your applications based on a few
criteria, such as the endpoint health of the server instance, the
geographic location of the user, and latency. Which AWS service is
most appropriate for this scenario?
A. Amazon Route 53
B. Application Load Balancer
C. Network Load Balancer
D. Classic Load Balancer
12. Your compliance team wants to audit your AWS environment to gain the
event history of all your AWS account activity, including any actions
taken using the AWS Management Console, AWS SDKs, or command-
line tools. Which AWS service tracks user activity and API usage?
A. Amazon CloudWatch
B. AWS CloudTrail
C. Amazon VPC Flow Logs
D. Amazon Cognito
13. You have strict requirement to protect stored data against site-level
failures, errors, and threats. Which AWS service provides unmatched
durability by automatically storing data across multiple availability
zones within an AWS region?
A. Amazon Neptune
B. Amazon RDS
C. Amazon S3
D. Amazon Timestream
14. You want to use a content delivery network (CDN) service to deliver
data and videos securely to your global customers, with low latency and
high transfer speeds. Which of the following AWS service will provide
the CDN capability?
A. Amazon DynamoDB
B. Amazon S3
C. Amazon Route 53
D. Amazon CloudFront
15. You have large amount of data in tape storage in an on-premises
datacenter, and you want to migrate it to AWS to save costs and to meet
long-term backup compliance requirements. Which AWS service
provides data archival at a low cost?
A. Amazon S3 Glacier
B. Amazon S3
C. Amazon CloudFront
D. Amazon RDS
16. You want to create and manage AWS users and groups to allow and
deny access to AWS resources, but you do not want to pay for this
service. Which of the following services provides this capability?
A. AWS IoT Core
B. Amazon Simple Notification Service (SNS)
C. AWS CloudFormation
D. AWS Identity and Access Management (IAM)
17. You have 75 terabytes of life sciences data in your datacenter and want
to move to the AWS cloud quickly and efficiently. Which of the
following services could quickly move the data to S3?
A. AWS Snowball
B. Amazon Redshift
C. Amazon DynamoDB
D. Amazon S3
18. Your company wants to use a dedicated network connection from on-
premises to AWS to reduce network costs and increase bandwidth
throughput without using the Internet. Which of the following services
provides these capabilities?
A. Amazon VPC
B. AWS CloudFront
C. AWS VPN
D. AWS Direct Connect
19. Your new application needs a hybrid storage service that enables your
on-premises applications to store data on AWS cloud storage. Which of
the following provides the hybrid storage service?
A. AWS Storage Gateway
B. Amazon S3
C. Amazon S3 Glacier
D. Amazon EBS
20. You are developing an application that will be used by millions of
users, and you want your users to sign-up and sign-in easily using social
identity providers such as Facebook, Google, and Amazon. Which of the
following services helps you to achieve this solution?
A. Amazon Macie
B. Amazon Inspector
C. Amazon Cognito
D. Amazon GuardDuty
21. You want use a managed distributed denial of service (DDoS)
protection service to safeguard your applications that are running on
AWS. Which AWS service provides always-on detection and automatic
inline mitigations for DDoS protection?
A. Amazon Macie
B. AWS Shield
C. Amazon GuardDuty
D. AWS WAF
22. You want to use a web application firewall that helps protect your web
applications from SQL injection and cross-site scripting. Which of the
following services could be used to protect your web application?
A. AWS WAF
B. AWS Shield
C. Amazon Inspector
D. Amazon Macie
23. You want to automate the build, test, and deploy phases of your release
cycle every time there is a code change. Which of the following
developer tools services could you use?
A. AWS CodeBuild
B. AWS CodeCommit
C. AWS CodeDeploy
D. AWS CodePipeline
24. Your team wants to automate software deployments to eliminate the
need for error-prone manual operations. Which of the following
developer tools services automates software deployments?
A. AWS CodeBuild
B. AWS CodeCommit
C. AWS CodeDeploy
D. AWS CodePipeline
25. You want use an automated process to compile your source code, run
tests, and produce software packages that are ready to deploy. Which of
the following developer tools automates the compilation and tests your
software packages?
A. AWS CodePipeline
B. AWS CodeDeploy
C. AWS CodeCommit
D. AWS CodeBuild

Answers
1. B, C, D. A traditional three-tier architecture consists of the Web tier,
Application tier, and Database tier. In AWS, the Web tier will be in the
public subnet, and the Application and Database tiers will be in a
private subnet.
2. C. There will be at least two availability zones in each AWS region to
provide high availability and fault tolerance to your applications.
3. C. Amazon Virtual Private Cloud (VPC) provides a logically isolated
section of the AWS cloud and acts as a networking layer for your EC2
instances and database services.
4. D. Amazon S3 (Simple Storage Service) will help you host a static
website without your having to provision and maintain any servers.
5. B. Amazon CloudWatch provides those metrics in one-minute and five-
minute intervals. You can use a Personal Health Dashboard to monitor
the EC2 instance’s performance.
6. A. Amazon EC2 Auto Scaling will automatically detect when an
instance is unhealthy, terminate it, and replace it with a new one.
7. C. With Amazon Athena, you can query data stored in Amazon S3 by
defining the schema. You start querying using standard ANSI SQL.
8. A. Using AWS Lambda, you can run your code without provisioning or
managing servers. Your company would pay only for the compute time
that you consume, and there is no charge when your code is not running.
9. B. Amazon Relational Database Service (Amazon RDS) automates
time-consuming database administration tasks, such as database
installation, patching, and daily backups.
10. D. Amazon ElastiCache offers fully managed, in-memory data stores
that can be used to build data-intensive gaming applications to provide
high throughput and low latency for your users.
11. A. The Amazon Route 53 service routes your traffic based on the
endpoint health of your instance, the geographic location of the user, and
latency.
12. B. AWS CloudTrail helps you monitor continuously and provides event
history of all AWS account activity.
13. C. Amazon S3 provides 99.99999999999 percent durability by storing
data across multiple systems within an AWS region.
14. D. Amazon CloudFront is a CDN service that securely delivers videos,
data, and applications to your customers.
15. A. Amazon S3 Glacier provides extremely low-cost cloud storage for
long-term backup.
16. D. The AWS Identity and Access Management (IAM) service can be
used to create and manage AWS users and groups to allow and deny
access to AWS resources at no charge.
17. A. The AWS Snowball service could be used to transfer the data to the
device, which is then shipped back to AWS, where the data is copied
into your S3 bucket.
18. D. AWS Direct Connect provides private connectivity between AWS
and your datacenter using a dedicated network connection to reduce
network costs and increase bandwidth throughput without using the
Internet.
19. A. The AWS Storage Gateway service provides hybrid storage service
that enables your on-premises applications to store data on the AWS
cloud.
20. C. Amazon Cognito scales to millions of users and supports sign-in with
social identity providers via SAML 2.0.
21. B. AWS Shield provides a managed DDoS protection service that
minimizes application downtime and latency.
22. A. The AWS WAF service acts as web application firewall and protects
your web applications from common attack patterns such as SQL
injection.
23. D. AWS CodePipeline is a fully managed continuous delivery service
that helps you automate the build, test, and deploy phases of your
release cycle every time there is a code change.
24. C. AWS CodeDeploy is a managed deployment service that automates
software deployments and makes it easier to rapidly release new
features, while avoiding error-prone manual operations.
25. D. AWS CodeBuild is a managed continuous integration service that
compiles your source code, runs tests, and produces software packages
that are ready for deployment.

Additional Resources
• What is cloud computing? Visit this site for in-depth information about
cloud computing, including types and benefits.

• Cloud Computing with AWS Consult this site to learn more about
AWS and global network infrastructures, read customer stories, and so
on.

• AWS Blog This blog is organized by various categories, such as


Compute, Database, DevOps, Storage, and Networking.
• AWS News Blog Read this blog periodically to learn what new AWS
services and features are being launched.

• AWS Training and Certification Here you can find free digital
training by AWS and AWS certification details. You can also register for
the AWS Certification exam when you are ready.

• AWS FAQs This important resource for exam preparation lists the
products and technical FAQs.

• Cloud Products Explore AWS products on this site.

• AWS Solutions Consult this site if you need help solving common
problems and building faster. It offers solution details, a deployment
guide, and instructions for automated deployment.

• AWS Documentation and News Blog On these two sites, you’ll find
user guides, developer guides, API references, tutorials, and more.
There is no place like official AWS documentation to get the latest and
correct information about all the AWS services. Always refer to the
official AWS blogs to get the latest updates about new AWS services
and updates to existing features.

• AWS Partner Network This site offers information about the global
partner program for businesses that use AWS to build solutions and
services for customers. It provides valuable business, technical, and
marketing support.
CHAPTER 2

Interacting with AWS Using API,


SDK, and CLI
In this chapter, you will learn
• Create new AWS account
• Explore AWS free services
• AWS Management Console
• AWS command line interface
• AWS Software Development Kit
• AWS tools for PowerShell
• AWS serverless application model
• AWS integrated development environment toolkits

I am excited to welcome you to this chapter, which will discuss how to


create a new AWS account and various ways of connecting to your AWS
services. As an AWS developer, you need to know and be familiar with
various tools that are available to connect and interact securely with AWS
services.

Create a New AWS Account


AWS accounts are available for free for 12 months to help you familiarize
yourself with various AWS services. To create a new AWS account, go to
https://aws.amazon.com/free, which is shown in Figure 2-1.
Figure 2-1 AWS Free Tier launch page

Click the Create a Free Account button to open the next screen, shown in
Figure 2-2.

Figure 2-2 AWS free account creation page

Enter your e-mail address and a password for your AWS root account.
Enter a name for your AWS account (this can be changed later). Click
Continue after you entered the required information to open the next screen,
shown in Figure 2-3.
Figure 2-3 Contact information

In this screen, select Professional if you intend to use this AWS account
within your company, educational institution, or organization. Otherwise,
select Personal and provide your contact details. Then read through the AWS
Customer Agreement and click the check box to indicate that you’ve read it,
before clicking Create Account and Continue. The next page is shown in
Figure 2-4.
Figure 2-4 Payment information

Enter your credit or debit card number, the card’s expiration date, and
cardholder’s name and billing address. Click a button to indicate whether the
billing address is the same or different from your contact address. Click
Secure Submit to open the Select A Support Plan page, shown in Figure 2-5.
Figure 2-5 Select a Support Plan page

CAUTION Be aware that this is not a 100 percent free account, because
you will be charged if you exceed the free limit quota. (The free quota
available for each service is explained at
https://aws.amazon.com/free/explains.) It’s always a best practice to delete
any resources that you don’t need. You can also set up a cost budget to
monitor your costs against a specified dollar amount (for example, you can
set up a budget for $50 and you can receive alerts when your user-defined
thresholds are met) or usage budget. You can monitor your usage of one or
more specified usage types or usage type groups (for example, monitor your
monthly EC2 instance free usage hours and receive alerts when your user-
defined thresholds are met) and receive an e-mail alert if you reach your
predefined thresholds for the month.

On the Select a Support Plan Page, you can choose the level of support
you need for your AWS account. AWS offers four different plans: a Basic
Plan, which is free; a Developer Plan, which currently starts at $29 per
month; a Business Plan, which currently starts at $100 per month; and an
Enterprise Support plan, which currently costs $15,000 per month and
provides premier support for your mission-critical production workloads.
You’ll read more about AWS free services in the next section.
Once you select the plan and provide your contact phone number, your
new AWS free tier account will be created and a confirmation e-mail sent to
the root user e-mail address.
Type https://console.aws.amazon.com in your browser’s search bar to
launch the sign-in page shown in Figure 2-6, where you’ll enter your root
user ID (the e-mail ID you used to create the AWS account) and password.
Figure 2-6 AWS sign-in page

As soon as you’ve logged in the first time, you’ll be routed to the AWS
Services page, shown in Figure 2-7. Type IAM in the search bar to begin
setting up the AWS Identity and Access Management (IAM) service. Click
IAM, from the search drop-down, to launch the IAM service console. Then
you’ll follow the IAM best practices to secure your account.

Figure 2-7 Type IAM in the search bar


CAUTION In IAM console, the best security practice is to delete your
AWS root account access keys. Instead, use your IAM user access keys or
temporary security credentials. You should never use your AWS root account
for day-to-day interaction with AWS operations, because the root account
provides unrestricted access to your AWS resources. You can also activate
multifactor authentication (MFA) on your AWS root account to add another
layer of protection. This will help to keep your account secure. For more
information on IAM best practices, see
https://docs.aws.amazon.com/IAM/latest/UserGuide/best-practices.html.

When you create IAM groups and users, you should always apply default
access policies or custom access policies based on the least privilege access
requirements of the users or groups who will be using IAM. This simplifies
managing and auditing permissions in your account.

NOTE I will be discussing IAM and security practices in great detail in


Chapter 10.

Explore AWS Free Tiers


When you choose the Basic Plan option, you can select from three tiers of
free options based on the product you use:
• Always Free Some AWS services are always free; in other words, use
of these services does not expire even after your free use term ends.
These services are available to all AWS customers.
• 12 Months Free AWS offers free usage for certain services for 12
months from your initial sign-up day. After 12 months, you pay standard
service rates.
• Trials These short-term free trial offers are available for many
different software solutions. After the trial period expires, you pay
standard service rates.
You can explore the following services during the free-trial period:
• Amazon EC2 750 hours per month, with 750 hours of Linux, RHEL, or
SLES t2.micro instance usage and 750 hours of Windows t2.micro
instance usage
• Amazon S3 5GB of free standard storage, 20,000 get requests, and
2000 put requests
• Amazon RDS 750 hours per month of db.t2.micro database usage for
MySQL, PostgreSQL, MariaDB, Oracle BYOL, or SQL Server,
including 20GB of General Purpose (SSD) database storage and 20GB
of storage for DB Snapshots and database backups
• Amazon DynamoDB 25GB of storage, with 25 provisioned write
capacity units (WCUs) and 25 provisioned read capacity units (RCUs);
enough to handle up to 200 million requests per month.
• Amazon SageMaker 250 hours per month of t2.medium notebook
usage for the first two months and 50 hours per month of m4.xlarge for
training for the first two months, along with 125 hours per month of
m4.xlarge for hosting for the first two months
• AWS Lambda 1 million free requests per month and up to 3.2 million
seconds of compute time per month
• Amazon Lightsail 750 hours per month, with a trial of the $3.50
Lightsail plan free for one month when using Linux/Unix; also a trial of
the $8 plan free for one month when using Lightsail for Microsoft
Windows Server.
• AWS Elastic Load Balancing 750 hours per month shared between
Classic and Application Load Balancers with 15GB of data processing
for Classic Load Balancers and 15 LCUs for Application Load
Balancers
• AWS Key Management Service 20,000 free requests per month
• AWS Storage Gateway First 100GB per account is free, and no data
transfer charges into AWS
• AWS Trusted Advisor Four best-practice checks on performance and
security (service limits, security groups, IAM, and MFA); notification
and customization features
• AWS CodeBuild 100 build minutes per month of build.general1.small
compute type usage
• AWS CodeCommit Five active users per month along with 50GB per
month of storage and 10,000 Git requests per month
• AWS CodePipeline One active pipeline per month
• AWS Data Pipeline Three low frequency preconditions and five low
frequency activities
• AWS Database Migration Service 750 hours of Amazon DMS single-
AZ dms.t2.micro instance usage and 50GB of included General Purpose
(SSD) storage
• Amazon SWF 10,000 activity tasks and 30,000 workflow-days along
with 1000 initiated executions
• Amazon Redshift Two-month free trial of 750 DC2.Large hours per
month
• Amazon SES 62,000 outbound messages per month to any recipient
when you call Amazon SES from an Amazon EC2 instance directly or
through AWS Elastic Beanstalk, and 1000 Inbound messages per month
• Amazon EFS 5GB of storage
• Amazon Elastic Block Storage (EBS) 30GiB of Amazon EBS with
any combination of General Purpose (SSD) or Magnetic, and 2000,000
I/Os with EBS Magnetic storage along with 1GB of snapshot storage
• Amazon Glacier 10GB of Amazon Glacier data retrievals per month;
can be used any time during the month and also applies to Standard
retrievals
• Amazon ElastiCache 750 hours of cache.t2micro node usage along
with enough hours to run continuously each month
• Amazon Elasticsearch Service t2.small.elasticsearch instance, 750
hours per month on a single AZ and 10GB per month of optional EBS
storage, either Magnetic or General Purpose
• Amazon CloudWatch Ten custom metrics and ten alarms, along with 1
million API requests, plus 5GB of log data ingestion and 5GB of log
data archive, and three dashboards with up to 50 metrics each per month
• Amazon API Gateway 1 million API calls received per month
• Amazon CloudFront 50GB of data transfer out and 2 million HTTP or
HTTPS requests
• Amazon Connect 90 minutes per month of cloud-based contact center
usage and a local direct inward dial (DID) number for the region; also
30 minutes per month of local inbound DID calls and 30 minutes per
month of local outbound calls
• Amazon SNS 1 million publishes and 100,000 HTTP/S deliveries,
along with 1000 e-mail deliveries

AWS Management Console


The AWS Management Console is an API-based web application that
provides easy access to all the AWS services. It comprises and refers to a
broad collection of service consoles for managing your Amazon Web
Services. When you first sign in, you see the console home page, shown in
Figure 2-8.
Figure 2-8 AWS Management Console home page

The home page provides access to all AWS services and corresponding
documentation and tips. If you navigate the individual service consoles in the
navigation pane, you’ll see tools for working with EC2—for example, AMIs,
Volumes, and Snapshots.
The AWS Management Console provides various ways for navigating to
individual service consoles. In the search field at the top of the console, enter
a service name—RDS was entered in Figure 2-9. Then choose the service
that you need from the list of search results.
Figure 2-9 Searching for the RDS service

From the console you can add shortcuts for the service consoles that you
use most frequently. To add a shortcut for the service consoles you use most,
choose the pushpin icon on the navigation bar, which is shown in Figure 2-
10. You can drag the service shortcut from the menu to the navigation bar.
Figure 2-10 Click the pushpin and drag a shortcut to the navigation bar

Figure 2-11 shows several shortcuts on the navigation bar. To remove a


shortcut that you no longer need, simply drag it off the navigation bar.

Figure 2-11 Shortcuts on the navigation bar

Along with other options on the navigation bar is a region option on the
right side of the bar. Click the region displayed in the bar to see a menu of
regions to choose from, as shown in Figure 2-12. When you choose a region
here, it becomes the default region used in the AWS Management Console.
Figure 2-12 Choosing a region

TIP Always make sure that you are working in the correct region—the one
for which you intend to create or work on AWS services. I have experienced
many people complaining that their resources are not available, only to
realize that they are working in the wrong region. Also, beware of instances
that use the same name in more than one region. When working in a
secondary region, it’s easy to inadvertently shut down an instance that uses
the same name used in the primary region, for example.
Even though you are able to choose a region that specifies where your
resources are managed, you do not choose a region for the AWS Management
Console or for some services, such as S3 and IAM.
In order to change the account settings, organization, billing dashboard,
or security credential to change the password.
Click your account name on the navigation bar, which is to the left of the
region menu. You’ll see the options shown in Figure 2-13. Click My Account
to access the following information about your user account:
• Account Settings
• Contact Information
• Payment Currency Preference
• Configure Security Challenge Questions
• AWS Regions
• IAM User and Role Access
• Reserved Instance Marketplace Settings
• Account Contract Information
• Communication Preferences
• Manage AWS Support Plans
• GovCloud (US)
• Close Account
Figure 2-13 Account information

If you are an account owner, you can change your AWS account password
from the AWS Management Console. Click your account name on the
navigation bar and select Security Credentials. Then follow the instructions
to navigate to the page where you can change your password. You need to
enter your current password and your new password two times. The new
password must follow the minimum password standard (at least eight
characters long and must include a symbol, a number, an uppercase letter, and
a lowercase letter). Once you’ve filled out the password form, choose
Change Password or Save Changes.
If you are a root user or have the necessary permissions, you can get
information about your AWS charges from the console. Click your account
name on the navigation bar and select My Billing Dashboard. The AWS
Billing and Cost Management dashboard provides a summary a breakdown
of your monthly spending.
Another important resource for all the AWS users is the Support menu, at
the far-right side of the navigation bar, and shown in Figure 2-14. Use the
Support menu to navigate to Support Center, Forums, Documentation,
Training, and Other Resources. Visit the Support Center to create support
tickets with AWS for any issues or to increase any soft limits. Forums are a
treasure to AWS users and developers, because you’ll quickly and easily find
solutions to many real-world scenarios or issues that have already been
resolved by another developer. This can help you avoid reinventing the
wheel. Choose Documentation, Training, or Other Learning Resources to find
more information about AWS, training options, and other sources of
information.

Figure 2-14 Support menu options

The bell menu on the navigation bar offers a quick way to see any open
issues or scheduled changes. In this menu, you’ll see the options Open Issues,
Scheduled Change, Other Notifications, and View All Alerts, as shown in
Figure 2-15. Select an option to be directed to the CloudWatch dashboard,
where you can quickly glance at all the open issues or scheduled changes.
Figure 2-15 Alerts menu options

The Resource Groups menu is located on the left side of the navigation
pane, as shown in Figure 2-16. (You can also access a resource group by
using the Resource Groups API via the AWS CLI or by using AWS SDK
programming languages, but you’ll learn more about these options later.) You
use resource groups to organize your AWS resources. Resource groups make
it easier to manage and automate tasks on large numbers of resources at one
time, instead of accessing them one at a time. From this menu, you can save
or create a resource group.

Figure 2-16 Resource Groups menu

An important and very useful option on this menu is the Tag Editor. A tag
is a key-value pair that acts as metadata for organizing all your AWS
resources. You can add tags for most AWS resources during resource
creation, whether your working with an Amazon S3 bucket or an Amazon
EC2 instance. You can then build a query for resources of various types, and
add, remove, or replace tags for the resources from your search results.

AWS Command Line Interface


The AWS Command Line Interface (CLI) is an open source tool you can use
to interact with AWS services using command-line shell. You can start using
AWS functionality with minimal configuration from the command prompt by
using following programs:
• Linux shells Use common shell programs such as bash, zsh, and tsch to
run commands in Linux, macOS, or Unix.
• Windows command line Run commands in PowerShell or at the
Windows command prompt.
• Remote Access Run commands on Amazon EC2 instances through a
remote terminal such as Secure Shell (SSH) or PuTTY.
All the functions available in the AWS Management Console are
available in the AWS API and CLI immediately, or within 180 days of launch
of any new service. Install the AWS CLI using pip3. You’ll need Python 2
version 2.6.5 or later, or Python 3 version 3.3 or later. The CLI can be
installed on Windows, Linux, macOS, or Unix.
As you will see, the AWS CLI uses a multipart structure on the command
line that must be specified in this order:

EXAM TIP Be sure that you understand the structure of a CLI base
command that calls to the AWS program. The top-level command typically
corresponds to an AWS service supported by the AWS CLI. The
subcommand specifies which operation to perform. Depending on the
command and subcommand you specify, parameters can take various types of
input values, such as numbers, strings, lists, maps, and JSON structures.

Installing and Setting Up a Profile in the AWS CLI


If you already have pip3 and Python v3 or later, you can install the AWS CLI
by using the following command:

The --upgrade option instructs pip3 to upgrade any requirements that are
already installed. The --user option instructs pip3 to install the program to a
subdirectory of your user directory.
The bundled installer is for offline or automated installations on Linux,
macOS, or Unix and includes the AWS CLI, its dependencies, and a shell
script that performs the installation for you. You can also use the MSI
installer on Windows.
After installing the AWS CLI, you need to add the path to the executable
file to your PATH variable. For Linux, macOS, or Unix, add the AWS CLI
executable to your command-line path like this:

This will add a path, ~/.local/bin, to your current PATH variable.


To load the updated profile into your current session, execute the
following:

In Windows, you can find where the AWS program is installed by running
the following command. The /R path parameter tells it to search all folders.

Press the key on your keyboard, type cmd in the search box, and
press to open the Environment Variable. You can also find the command
prompt in the Windows accessories. You need to choose Edit environment
variables for your account. Here you can choose PATH, and then choose
Edit. Then add the path to the end of the variable value field (such as
C:\Program Files\Amazon\AWSCLI\bin\aws.exe). The following example
shows the system PATH of aws.exe:

The AWS CLI stores the credentials in a local file named credentials, in
the .aws folder. For Windows, use the following command to show the
contents of the .aws folder:

And for Linux, macOS, or Unix, use the following to list the contents of
the .aws folder:

The AWS CLI provides low-level, API-equivalent commands. But


several AWS services provide customizations and direct access to the public
APIs of AWS services, and you can customize using higher-level commands
that simplify using a service with a complex API. For example, the following
example provides a shell-like copy command and automatically performs a
multipart upload to transfer large files quickly to Amazon S3:

If you performed a similar task using the low-level commands, it would take
a lot more effort.

Configuring Profiles
To configure a new profile, at the command line, enter aws configure, and
then press . This command is interactive, so the AWS CLI outputs lines
of texts, prompting you to enter additional information. Enter each of your
access keys in turn, and then press . Then, enter an AWS region name in
the format shown next, press , and then press a final time to skip
the output format setting.

This will result in a single profile named default.


You can create additional configurations by specifying the name of a
profile using the --profile option to configure multiple users:
When you run an AWS command, you can omit the --profile option to use
the default profile:

And you can specify a profile name with --profile to create a profile
stored under that name:

To retrieve a value for any setting, use the get subcommand to view the
current settings:

To modify the current setting, use the --profile option. For example, the
following command updates the region setting in the profile named
myuserprofile:

The following command updates the output setting in the profile named
myuserprofile:

Here is a simple noninteractive command to output from the service in


the JSON format:
To use this example, enter the full text of the command (the bold text after the
prompt), and then press . (The name of the security group, my-secgrp, is
replaceable. You could use the group name as shown, but you probably want
to use a more descriptive name.) Note that the information within the curly
braces is the JSON output of the command. JSON is the default output format,
but if you configure your CLI to output in table or text format, the output will
be formatted according to your choice.
To avoid specifying the profile in every command, you can set the
AWS_DEFAULT_PROFILE environment variable at the command line. In
Linux, macOS, or Unix, use the following:

This changes the default profile until the end of your shell session, or
until you set a different value. You can make an environment variable
persistent across future sessions by adding the variable to the shell’s startup
script.
Here’s how it looks in Windows:

Using setx to set an environment variable affects the value used in both the
current command shell and all command shells that you create after running
the command.

Getting Help with CLI Commands


AWS offers a CLI command-completion feature: press to complete a
partially typed command. This feature is automatically configured and
enabled by default on EC2 instances, but it isn’t automatically installed on
most systems, so you’ll need to configure it manually if you want to use it.
Here’s an example: to see a list of available commands, enter a partial
command, s in this case, and then press :
You can always get help with any command when using the AWS CLI.
Simply type help at the end of a command name:

Here’s how to get help for Amazon EC2–specific commands.

To view the help file one page at a time, you can add a pipe (|) to the
output of the help command to add the more command. Press the or
to view more of the document, or press to quit.

Working with EC2 Key Pairs Using the AWS CLI


When you create an EC2 instance, you need to provide a key pair that you’ll
use to authenticate when you try connecting to the instance.
To create a key pair on Linux, use the create-key-pair command with the -
-query and --output text options to pipe your private key directly into a file:

Before you try connecting to your instance from a Linux computer, you
need to change the permissions of your private key file so that only you can
read it:

To display your key pairs, use the following command:


To delete a key pair, use the following command:

Note that in Windows PowerShell, the > file redirection operator


defaults to UTF-8 encoding, so you must convert the output by piping it to the
out-file command by explicitly setting the -encoding option to ascii:

Creating Security Groups Using the AWS CLI


You can create security groups associated for a specified Amazon Virtual
Private Cloud (VPC) using the following command:

Use the describe-security-groups command to view initial information


about your new security group. Notice that an EC2-VPC security group is
referenced by its VPC ID (VcpID), not by its name:
Confirm your public address using following command:

You can add a range to your security group to limit all the ingress traffic:

To enable SSH to instances in the my-sg-grp security group, add a rule by


running the following command:

To view changes to the security group, use the describe command, as


follows:
To delete a security group, use the delete-security-group command:
NOTE You will not be able to delete a security group if it’s currently
attached to an instance.

Launching an Instance Using the AWS CLI


You can launch an Amazon EC2 instance by using the run-instances command
to launch a t2.micro instance in the specified subnet of a VPC:

To add metadata to your resources that you can use for a variety of
purposes, add tags to your instance by using the create-tags command:

Using AWS CLI, you can list all your instances or filter the results based
on the instances that you want to see:

You can list multiple instances that were launched using ami-i7654321,
ami-j7654321, or ami-k7654321 using the following command:

To terminate an instance you no longer need, use the terminate-instances


command:
NOTE If you think you may need to reconnect to this instance later, use
stop-instances instead of terminate-instances, because as soon as the state of
the instance changes to terminated, it can’t be recovered unless you have a
manual backup. You stop incurring charges for a terminated instance.

Creating an S3 Bucket Using the AWS CLI


Bucket names must be globally unique and should be DNS compliant. The
names must start with a lowercase letter or number and can contain
lowercase letters, dashes, periods, and numbers. They cannot contain
underscores, have consecutive periods, end with a dash, or use dashes
adjacent to a period.
To create an S3 bucket, use the s3 mb command:

To list your S3 buckets, use the s3 ls command:


To list all the objects and folders in a bucket, use the following
command:

To delete an S3 bucket, use the s3 rb command:

TIP You must delete all the contents in the bucket before the bucket can be
deleted; the s3 rb command will fail if the bucket is not empty. You can,
however, remove a non-empty bucket by including the --force option.

To remove all the objects and subfolders in a bucket and then delete the
bucket, use the following command:

NOTE If versioning is enabled for this bucket, this command does not
allow you to remove the bucket.
AWS Software Development Kit
The AWS Software Development Kit (SDK) enables you to simplify the use
of AWS services in your applications with an API tailored to your
programming language or platform.

AWS SDK for Java 2.0


Before you can begin the AWS SDK for Java setup, you need to create an
IAM user and access key. In the AWS Management Console, navigate to the
IAM Console. From the side menu, click Users to view a list of IAM users.
You can log in using an existing user account or create a new account.
Assuming you have already set up an IAM user account, select an IAM user
from the list and open the Security Credentials tab, and then click Create
Access Key. Here you can either click the Download Credentials button to
download the credential file to your computer, or click Show User Security
Credentials to view the IAM user’s access key ID and secret access key,
which you can copy and paste, to use later.
Depending on your build system or integrated development environment
(IDE), you can use the following build tools:
• Gradle Import the Maven bill of materials (BOM) to your Gradle
project to automatically manage SDK dependencies.
• Apache Maven Specify only the SDK components you need as
dependencies in your project. If you build the AWS SDK for Java using
Maven, it downloads all the necessary dependencies, builds the SDK,
and installs the SDK in one step.
If you’re using Maven, your next step is to open the AWS SDK for Java
2.x and click the Clone or Download button to choose your download option.
Then, from the terminal window, navigate to the directory where the
downloaded the SDK source is located. Use the following command to build
and install the SDK:

A .jar file will be built in the target directory. You can optionally build
the API reference documentation using the following command:
Java 8.0 or later is required for the AWS SDK, or you can use the Open
Java Development Kit (OpenJDK), which is distributed by Amazon Corretto.
AWS recommends that you use the 64-bit version of the Java Virtual Machine
(JVM) for the best performance of server-based applications with the AWS
SDK for Java.
You can set your credentials for use by the AWS SDK for Java in several
ways. You can set credentials in the AWS credentials profile file on your
local system at one of the following locations:
• Linux, macOS, or Unix ~/.aws/credentials

• Windows C:\Users\USERNAME\.aws\credentials

This profile file should contain the following format:

You’ll substitute your AWS credentials values for the values


your_access_key_id and your_secret_access_key.
To set these variables in Linux, macOS, or Unix, use the following:

To set these variables in Windows, use this:

By default, the credential provider chain loads credentials automatically as


soon as you issue one of the preceding commands.
Similarly, you can set a default AWS region to use for accessing AWS
services with the AWS SDK for Java. AWS recommends, for the best
network performance, that you choose a region that’s geographically close to
you or to your customers. You need to update the AWS config file on your
local system to set the AWS region:
• Linux, macOS, or Unix ~/.aws/config

• Windows C:\Users\USERNAME\.aws\config

The config file uses the following format:

NOTE Substitute your AWS region (for example, us-east-1) for


your_aws_region.

You can also use the AWS_REGION environment variable.


For Linux, macOS, or Unix, use the export command to set the region:

For Windows, use the set command to set the region:

AWS SDK for .NET


Before you can begin the AWS SDK for .NET setup, you need to create an
IAM user and access key. In the AWS Management Console, navigate to the
IAM Console. Click Users from the side menu to view your IAM users. You
can either use an existing user or create a new user. Assuming you have
already set up an IAM user account, select the IAM user from the list and
open the Security Credentials tab, and then click Create Access Key. Then
click the Download Credentials button to download the credential file to
your computer, or click Show User Security Credentials to view the IAM
user’s access key ID and secret access key, which you can copy and paste to
use later.
Creating a profile for each set of credentials in the SDK Store is the
preferred approach for handling credentials. You can create and manage
profiles with the AWS Toolkit for PowerShell using cmdlets, Visual Studio,
or programmatically with the AWS SDK for .NET. All the credentials are
encrypted and stored separately from any of your projects. When you
reference the profile using your application name, the credentials are inserted
at build time. This ensures that your credentials are not unintentionally
exposed with your project on any public site.
To install AWS SDK for .NET, you must have Microsoft .NET
Framework 3.5 or later and Microsoft Visual Studio 2010 or later. The AWS
SDK for .NET is installed with the AWS Toolkit for Visual Studio, along
with a plug-in that provides a user interface for managing your AWS
resources from Visual Studio. It also includes the AWS Tools for Windows
PowerShell.
To install the AWS SDK for .NET from the AWS Management Console,
navigate to AWS SDK for .NET. Then, in the Downloads section, choose
Download MSI Installer to download the installer. Run the downloaded
installer to start installation, and follow the on-screen instructions. You can
install the AWSSDK assemblies, as well as the TraceListener and
SessionProvider extensions, to your application by installing the AWS
assemblies with NuGet or by installing AWS SDK for .NET, available on
GitHub. You can choose a different installation directory to install AWS
SDK for .NET as a non-administrator.

AWS Tools for PowerShell


The AWS Tools for PowerShell Core and AWS Tools for Windows
PowerShell are PowerShell modules that are built on the functionality
exposed by the AWS SDK for .NET. The AWS PowerShell tools enable you
to script operations on your AWS resources from the PowerShell command
line. The cmdlets provide an idiomatic experience for specifying parameters
and handling results, even though the cmdlets are implemented using the
service clients and methods from the SDK. For example, you can pipe
PowerShell objects in and out of the cmdlets.
You can use the PowerShell tools with IAM user credentials, temporary
security tokens, and IAM roles. These tools can be installed on Windows,
Linux, or macOS operating systems.
In Windows
Depending on the release and edition, a Windows computer can run the AWS
Tools for Windows PowerShell, the AWS Tools for PowerShell Core, or
both. After you install Windows PowerShell 2.0 or later, you can either
download and run the AWS Tools for Windows PowerShell MSI installer or
start PowerShell.
The AWS Tools for Windows PowerShell is an optional component that
you can install for Windows installer .msi. To download the installer, go to
http://aws.amazon.com/powershell, and then choose AWS Tools for
Windows.
The AWS Tools for Windows PowerShell is installed by default on all
Windows-based Amazon Machine Images (AMIs). The AWS Tools for
PowerShell Core can be installed for all users by running the Install-Module
cmdlet as administrator:

To install both AWS PowerShell and AWS PowerShell.NetCore on a


Windows OS for the current user, run the following as administrator:

You need to uninstall the existing module before you install a newer
release of the AWS Tools for PowerShell Core. Close any open AWS tools
for Windows or PowerShell sessions before you uninstall the existing Tools
for PowerShell Core package. Then run the following command to uninstall
the package:

To install the updated module after the uninstall is completed, use the
following command:

After you install the module, run


to load the AWS Tools for PowerShell Core cmdlets into your PowerShell
session.

On Linux and macOSX


To set up the AWS Tools for PowerShell Core on Linux machines, search for
“Installing PowerShell on Linux” in your browser to see the latest
instructions (the URL is https://docs.microsoft.com/en-
us/powershell/scripting/install/installing-powershell-core-on-linux?
view=powershell-6). For macOS X, search for “Installing PowerShell on
macOS” in your browser (https://docs.microsoft.com/en-
us/powershell/scripting/install/installing-powershell-core-on-macos?
view=powershell-6).
AWS releases new versions of the AWS Tools for PowerShell Core and
AWS Tools for PowerShell periodically to support new AWS services and
features. To determine the version installed on your OS, run the following
cmdlet:

Before you uninstall the existing Tools for PowerShell Core package or
install a newer release, close any open PowerShell or AWS Tools for
PowerShell Core sessions by pressing - . Then run the following
command to uninstall the package:

To install the updated module after uninstall is completed, use the


following command:

After you install the module, run


to load the AWS Tools for PowerShell Core cmdlets into your PowerShell
session.

AWS Serverless Application Model


The AWS Serverless Application Model (SAM) is an open source
framework you can use to make serverless applications on AWS. A
serverless application is combination of event sources, Lambda functions,
and other resources that work together to perform certain tasks. A serverless
application is more than just a Lambda function, because it can include
additional resources such as APIs, databases, and event source mappings.
You can use AWS SAM to outline your serverless applications and use
the AWS SAM template specification to define your serverless applications.
The template provides a simple and clean syntax you can use to describe the
functions, APIs, permissions, configurations, and events that make up one,
deployable, versioned serverless application.

Using the AWS SAM CLI


The SAM CLI is an open source framework you use to create serverless
applications using a template. The CLI includes commands for invoking
Lambda functions locally, stepping through Lambda function debugging, and
verifying that AWS SAM template files are written according to
specifications regarding packaging and deploying serverless applications to
the AWS cloud.
Because SAM integrates with other AWS services in creating serverless
applications, it offers the following benefits:
• SAM makes it easy to organize related resources and components and
operate on a single stack. You can share timeouts and memory
configurations between resources using AWS SAM, and all the related
resources can be deployed together as a versioned entity.
• Because SAM is an extension of AWS CloudFormation, you’ll benefit
from the latter’s reliable deployment capabilities. You can use AWS
CloudFormation to define resources in your SAM template. You can also
use the full suite of resources, intrinsic functions, and other template
features that are available in CloudFormation.
• Use SAM to define and deploy your infrastructure as a configuration,
which makes it possible for you to enforce best practices, such as code
reviews. With a few lines of configuration, you can enable safe
deployments thru CodeDeploy and can enable tracing by using AWS X-
Ray.
• The SAM CLI enables you locally build, test, and debug serverless
applications that are defined by SAM templates. The CLI provides a
Lambda-like execution environment locally. You can catch issues
proactively by providing parity with the actual Lambda execution
environment.
• You can use SAM with AWS toolkits, such as the AWS Toolkit for
PyCharm, AWS Toolkit for JetBrains, AWS Toolkit for Visual Studio
Code, and AWS Toolkit for IntelliJ to step through and debug your code
and to understand what the code is doing. This tightens the feedback
loop by enabling you to find and troubleshoot issues in the cloud.
Use SAM along with a suite of AWS tools to build serverless
applications. New applications can be discovered in the AWS Serverless
Application Repository. Use the AWS Cloud9 IDE, for authoring, testing, and
debugging SAM-based applications. Use CodeBuild, CodeDeploy, and
CodePipeline to build a deployment pipeline for your serverless
applications. A CI/CD pipeline is automatically configured for you, and you
can also use AWS CodeStar to get started with a project structure, code
repository. You can use the Jenkins plug-in to deploy your serverless
application. To build production-ready applications, you can use the
Stackery.io toolkit.
Before installing the SAM CLI on macOS, Windows, and Linux, you must
do the following:
• Create an AWS account.
• Create an IAM user with administrator permissions.
• Install the AWS CLI.
• Install Docker.
For additional installation instructions, see
https://docs.aws.amazon.com/serverless-application-
model/latest/developerguide/serverless-sam-cli-install-mac.html.

Installing Docker on Linux


Assuming you’ve already created an AWS account and an IAM user, and
installed the AWS CLI, you can next install Docker, which is a prerequisite
for testing your applications locally. (For additional information, refer to
https://docs.aws.amazon.com/cli/latest/userguide/install-cliv2-docker.html.)
Before you can run serverless projects and functions locally with the SAM
CLI, Docker must be installed and running. The SAM CLI uses the
DOCKER_HOST environment variable to contact the Docker daemon.
To install Docker on Linux, in the left-hand column, choose Linux, and
then choose your Linux distribution.
To verify that Docker is working, run the docker ps command. (See
https://docs.aws.amazon.com/cli/latest/userguide/install-cliv2-docker.html
for additional information.)
You don’t need to install, fetch, or pull any containers because the SAM
CLI does this automatically.

AWS IDE Toolkits


You can create, run, deploy, and debug applications using language-specific
Integrated Development Environments (IDE), such as AWS Cloud9, Eclipse,
IntelliJ, PyCharm, Visual Studio, Visual Studio Code, Visual Studio Team
Services (VSTS), and Rider in Amazon Web Services.

The AWS Toolkit for Eclipse


The AWS Toolkit for Eclipse (https://aws.amazon.com/eclipse/) is an open
source plug-in for the Eclipse Java IDE that makes easier for developers to
develop, debug, and deploy Java applications that use AWS services. The
toolkit supports Windows, Linux, macOS, and Unix operating systems.
The Toolkit for Eclipse enhances the features of Eclipse IDE with the
following:
• When you create a new AWS project using the Toolkit for Eclipse, the
AWS SDK for Java is included and managed by Maven.
• AWS Explorer, an interface to AWS, lets you manage all your AWS
resources from within the Eclipse environment.
• AWS SAM project and AWS Lambda Java project blueprint creation,
deployment and debugging.
• AWS CodeCommit repository cloning
• Integration with AWS CodeStar
• AWS Elastic Beanstalk deployment and debugging
• An AWS CloudFormation template editor
• Support for multiple AWS accounts
The following are prerequisites for using the AWS Toolkit for Eclipse:
• Java 1.8 or higher
• Eclipse IDE for Java Developers 4.2 or later

NOTE If you want AWS Toolkit for Eclipse support for the AWS Mobile
SDK for Android, you must install Google Android Development Tools
(ADT).

Installing the AWS Toolkit for Eclipse


Here’s how to install the AWS Toolkit for Eclipse:
1. Open the Eclipse main console.
2. Within Eclipse, click on the Help and then click Install New Software
option.
3. In the Work with box, type https://aws.amazon.com/eclipse and then
press .
4. Now you can choose the components of the AWS Toolkit for Eclipse
that you want to install. Click Select All to install all the components at
once. Only the AWS Toolkit for Eclipse Core is mandatory and all other
components are optional.
5. Click Next to complete installation, once you have made all your
selections.
6. After you have set up the AWS Toolkit for Eclipse then you should
configure your AWS Credentials.
It may take up to 30 minutes for the installation to complete, depending on
the options selected, and on factors such as network speed, server latency,
and system capabilities.

Upgrading the AWS Toolkit for Eclipse


You can use the same instructions for installing the toolkit for upgrading or
reinstalling the AWS Toolkit for Eclipse. Due to a bug in old versions of the
Oomph plug-in, some versions of Eclipse, (Mars and Neon), may fail to fetch
the latest artifacts. But there is a work around for this issue:
1. The AWS Toolkit for Eclipse update site should point to
https://aws.amazon.com/eclipse/site.xml
2. Then delete the ~/.eclipse/org.eclipse.oomph.p2/cache/ directory to
remove any cached content.
3. Finally install the latest version of Oomph.

The Toolkit for Visual Studio


It is easier to develop, debug, and deploy .NET applications using AWS
Toolkit for Visual Studio is a plug-in for the Visual Studio IDE that use
Amazon Web Services. Visual Studio versions 2013 and later are supported.
In order to install and configure the Toolkit for Visual Studio, you must
have the following prerequisites.
You should have Windows 10, Windows 8, or Windows 7 operating
system. It is recommended to install the latest service packs and updates for
the Windows version you’re using.
You need to use Visual Studio 2013 or later including Community
editions. It is recommended to install the latest service packs and updates.
The Toolkit for Visual Studio for Visual Studio 2019 and Visual Studio
2017 is distributed in the Visual Studio Marketplace. Also, you can install
and update the toolkit using the Extensions and Updates dialog your existing
Visual Studio.
The Toolkit for Visual Studio 2015 and 2013 versions are part of the
AWS Tools for Windows.

Installing the Toolkit for Visual Studio in Windows


First, you need to download the installer for the AWS Toolkit for Visual
Studio. The toolkit itself is installed automatically. Here’s how to do this in
Windows:
1. Go to the page AWS Toolkit for Visual Studio.
2. Choose Toolkit for Visual Studio 2013–2015 to download the installer,
from the Download section.
3. Run the downloaded installer to start the installation, and follow the
instructions.
The Toolkit for Visual Studio is installed by default in the Program Files
directory, which requires administrator privileges. You can specify a
different installation directory to install the Toolkit for Visual Studio as a
non-administrator.

Uninstalling the Toolkit for Visual Studio in Windows


You must uninstall the AWS Tools for Windows before you can uninstall the
AWS Toolkit for Visual Studio.
1. Open Programs and Features in the Control Panel.
2. You can run appwiz.cpl from a command prompt or the Windows Run
dialog to open Programs and Features directly.
3. You need to choose AWS Tools for Windows, and then choose Uninstall
to begin the installation.
4. You need to choose Yes to continue.
Samples directory doesn’t get deleted after uninstalling the AWS Tools
for Windows. This directory is saved for you in case you have modified the
samples. You can manually remove this directory if you want to remove it.
AWS Tools for Visual Studio Team Services
Microsoft Visual Studio Team Services (VSTS) extension is AWS Tools for
Microsoft Visual Studio Team Services. It contains tasks you can use in
release and build definitions in VSTS and Microsoft Team Foundation
Server (TFS) to interact with AWS services. The Visual Studio Marketplace
has the AWS Tools for VSTS.

Installing AWS Tools for Visual Studio Team Services


You need to install the AWS Tools for VSTS to begin the setup and you also
need to set up AWS credentials to use the tasks using either service
endpoints, Amazon EC2 instance metadata or environment variables.
To use Visual Studio Team Services (VSTS), you will first need to sign
up for a Visual Studio Team Services Account. Then you can install the AWS
Tools for VSTS Extension.
The AWS Tools for VSTS can be installed from Visual Studio
Marketplace. Do the following:
1. Sign in to your VSTS account, and then search for AWS Tools for
Microsoft Visual Studio Team Services. You can choose Download to
install into an on-premises Team Foundation Server or you can choose
Install to download to VSTS. Download Team Services Extension and
start setting up AWS Credentials for the AWS Tools for VSTS. You
need to sign in to AWS and open IAM console to create an IAM user.
Then choose Users in the sidebar to view your IAM users.
2. If you don’t have any IAM users set up already then choose Create New
Users to create new User. You then need to select the IAM user from the
list that you want to use to access AWS. Now open the Security
Credentials tab and then choose Create Access Key. AWS allows you to
have a maximum of two active access keys for any IAM user. If this
IAM user has two access keys already then you need to delete one
before creating a new key.
3. From the pop-up dialog box that opens in a new window, you can either
choose Download Credentials to download the file to your computer or
choose Show User Security Credentials to view and can copy and paste.
Once you close the dialog box, there is no way to obtain the secret
access key. However, you can delete its associated access key ID and
create a new key.
You can supply credentials to the tasks in the following ways:
• You can configure a service endpoint, of type AWS, and reference the
endpoint when configuring tasks.
• You can create specific named variables in your build. The variable
names for supplying credentials are AWS.SecretAccessKey,
AWS.AccessKeyID, and AWS.SessionToken. In order to pass the region,
you need to specify AWS.Region with the region code (eg us-east-1) of
the region.
• You can use the standard AWS environment variables in the build agent
process. These variables are AWS_SECRET_ACCESS_KEY,
AWS_ACCESS_KEY_ID, and AWS_SESSION_TOKEN. In order to
pass the region, you need to specify AWS.Region with the region code
(eg us-east-1) of the region.

Chapter Review
This chapter began by explaining all the necessary steps that you need to
create a new AWS free account. Because as a developer, it’s crucial for you
to have a free AWS account to practice everything. I then explained all the
free services and limits that are available to you during the trial period and
beyond. It’s another important thing that you need to be aware while working
with AWS because if you exceed the free limit then you will be charged by
AWS. I then, introduced you the AWS management console where you
learned how to search any AWS service using the search box, adding and
removing shortcuts for the services that you use frequently. Then we explored
on how to change a region, as well as account information where you can
change the security credentials, see the support plans, GovCloud, and have
an option to close the account. Then we delve into the Support Center, Alerts,
Resource Group, and Tag Editor on the navigation pane. You also learned
how to install, configure, and how to control multiple AWS services from the
command line and automate them through scripts using the AWS Command
Line Interface (CLI).We then introduced the AWS SDK, which removes the
complexity of hard coding against a service interface and making it easier to
code applications. By providing many of Java API for many of AWS
Services, the AWS SDK for Java helps take the high complexities out of
coding. It is the collection of all the developer’s tools for the creation of
.Net-based applications that run on AWS infrastructure, and it also helps to
make AWS services and applications available through the web browser
across many devices and operating systems in a reliable manner.
We also learned AWS PowerShell administration by installing and
configuring the AWS PowerShell tools. The PowerShell helps administrators
and developers to manage the AWS services using PowerShell scripting
environment. We also explored how to run your serverless application
locally for quick development and testing by using AWS Serverless
Application Model (SAM). AWS SAM is open source and includes a
template specification, which is an extension of CloudFormation template
and a command-line interface (CLI) to invoke AWS Lambda functions and
debug applications deployed on the AWS cloud. Finally, we have gone
through the AWS Toolkit for Eclipse, which is an open source plug-in for the
Eclipse Java IDE (Integrated Development Environment) that makes it easier
for developers to develop, debug, and deploy Java applications that use
AWS services. Also explored were the AWS Toolkit for Visual Studio,
which is a plug-in for the Visual Studio IDE that makes it easier for
developers to develop, debug, and deploy .NET applications that use AWS
services. This chapter is the building block where we explored all the tools
that you need to build the secure cloud native applications on the AWS cloud.

Exercises
The following exercises will help you practice to use the AWS CLI and the
Console to perform various administrative tasks.
You need to create an AWS account as explained earlier in this chapter
for performing the following exercises. You can use the Free Tier when
launching AWS resources, but make sure to terminate them at the end.

Exercise 2-1: Create an IAM User Using the AWS


Management Console
In this exercise, you create a new IAM User using the Console.
1. Sign in to the AWS Management Console and use search IAM in the
console and go to https://console.aws.amazon.com/iam/.
2. Once you are in IAM navigation pane, choose Users and then choose
Add User option.
3. You then need to type the user name for the new user. If you want to add
more than one user at the same time, you can choose Add Another User
for up to 10 users at one time.
4. Select the type of access for this user, either you can select
programmatic access or access to the AWS Management Console, or
both access.
5. On the Set permissions page, you can specify how you want to assign
permissions from one of the following three options:
• Add user to group
• Copy permissions from existing user
• Attach existing policies to user directly
6. Choose Next. Here you can enter Tags, which is the metadata to the user
as key-value pairs.
7. Choose Next. Review all the options for the User.
8. You can choose Create User and then download access key IDs and
secret access keys.

Exercise 2-2: Enable Multi-Factor Authentication MFA for


an IAM User
In this exercise, you create an Enabling Multifactor authentication.
1. You need to first sign in to the AWS Management Console and open the
IAM console at https://console.aws.amazon.com/iam/.
2. In the IAM navigation pane, choose Users.
3. In the User Name list, choose the name to which you want to enable
MFA user.
4. Then you need to choose the Security credentials tab. Next to Assigned
MFA device you need to choose the Manage option.
5. From the Manage MFA Device wizard, you need to choose Virtual MFA
device and then select Continue.
6. Open your virtual MFA app.
7. Then you can do one of the following:
• From the wizard, you need to choose Show QR code, and use the app
to scan the QR code.
–or–
• From the Manage MFA Device wizard, you choose Show secret key,
and then type the secret key into your MFA app.
When it’s finished, the virtual MFA device starts generating one-time
passwords.
8. In the Manage MFA Device wizard, type the one-time password in
MFA code 1 box that currently appears in the virtual MFA device. Then
wait up to 30 seconds for the device to generate a new password. Now
type the second password into the MFA code 2 box.
9. Choose Assign MFA option.
10. Now the virtual MFA device is ready for use with AWS.

Exercise 2-3: Use an AWS CLI to Create a Custom VPC and


Subnets
In this exercise, you create a custom VPC and subnets.
1. You can create a custom VPC with a 192.168.0.0/16 CIDR block.

2. Then create a subnet with a 192.168.1.0/24 CIDR block.

3. Also create a second subnet in your VPC with a 192.168.2.0/24 CIDR


block.

4. In order to make your subnet public, you need to create an Internet


gateway.

5. Then you need to attach the Internet gateway to your VPC.


6. Create a custom route table for your VPC to route the traffic.

7. Now update the Route Table by creating a route that points all traffic
(0.0.0.0/0) to the Internet gateway.

8. You then need to associate it with a subnet in your VPC, so that the
traffic from that subnet is routed to the Internet gateway.

9. You need to modify the public IP addressing behavior of your subnet if


you want the instances launched into the subnet to automatically receive
a public IP address.

Exercise 2-4: Use an AWS CLI to Create a Key Pair


In this exercise, you use an AWS CLI to create a key pair.
1. Now you need to create a key pair, to launch and connect to an instance
in your public subnet.

2. In order to use an SSH client on a Linux or Mac OS X operating system


to connect to your EC2 instance, you need to use the following command
to restrict the permissions of your private key file.

Exercise 2-5: Use an AWS CLI to Create a Security Group


and EC2 Instance
In this exercise, you create an EC2 instance and security group using AWS
CLI.
1. Create a security group in your VPC, and add a rule that allows SSH
access from anywhere (it’s not recommended for allowing SSH access
from anywhere and you might need to restrict to known IP ranges).
2. You can now launch an EC2 instance into your public subnet, using the
security group and key pair that we have created in previous steps.

3. After your instance is in the running state, you can connect to it using an
SSH client from a Linux or Mac OS X computer by using the following
command:

Exercise 2-6: Use an AWS CLI to Delete the VPC and


Subnets
In this exercise, you delete the VPC and subnets using AWS CLI.
1. Once you’ve verified that you can connect to your EC2 instance, and
then you can terminate it if you no longer need it to save cost. So, we
need to delete the dependencies before deleting the VPC. First, delete
your security group:

2. Then you can delete your subnets:

3. And then you can delete your custom route table:

4. You need to detach your Internet gateway from your VPC before
deleting it.

5. Now you can delete your Internet gateway:

6. Finally, you can delete your VPC:


Questions
The following questions will help you gauge your understanding of the
contents in this chapter. Read all the answers carefully because there might
be more than one correct answer. Choose the best response for each question.
1. What parameters do you need to set up an AWS CLI? (Choose all that
apply.)
A. AWS Access Key ID
B. AWS Secret Access Key
C. Default region name
D. Default output format
2. What is the command to create EC2 key pair using an AWS CLI?
A. aws ec2 create-key-pair --key-name 'my key pair'

B. aws ec2 modify-key-pair --key-name 'my key pair'


C. aws ec2 delete-key-pair --key-name 'my key pair'

D. aws ec2 stop-key-pair --key-name 'my key pair'


3. Which of the following AWS CLI commands lists all your instances and
view information about those EC2 instances?
A. aws ec2 display-instances

B. aws ec2 describe-instances


C. aws ec2 discover-instances

D. aws ec2 show-instances


4. Which of the following AWS PowerShell commands can be used to list
your S3 bucket named my-s3-files?
A. PS C:\> Read-S3Object -BucketName my-s3-files

B. PS C:\> Get-S3BucketPolicy -BucketName my-s3-files


C. PS C:\>Copy-S3Object -BucketName my-s3-files

D. PS C:\>Get-S3Bucket -BucketName my-s3-files


5. You want to delete a S3 bucket named my-old-files. Which of the
following AWS PowerShell commands can be used to delete it?
A. PS C:\>Remove-S3Bucket -BucketName my-old-files
B. PS C:\>Delete-S3Bucket -BucketName my-old-files

C. PS C:\>Purge-S3Bucket -BucketName my-old-files


D. PS C:\>Drop-S3Bucket -BucketName my-old-files

6. Which of the AWS PowerShell commands retrieves a collection of


users in the current AWS account?
A. PS C:\>Retrieve-IAMUserList
B. PS C:\>Pull-IAMUserList

C. PS C:\>Show-IAMUserList
D. PS C:\>Get-IAMUserList

7. Mike left your team so you need to delete the IAM user named Mike
using AWS PowerShell. Which of the following commands achieves
this goal?
A. PS C:\>Remove-IAMUser -UserName Mike
B. PS C:\>Delete-IAMUser -UserName Mike

C. PS C:\>Drop-IAMUser -UserName Mike


D. PS C:\>Purge-IAMUser -UserName Mike

8. Which of the following is a CLI tool for local development and testing
of Serverless applications?
A. AWS PowerShell
B. AWS CLI

C. AWS SAM Local


D. AWS SDK

9. Your networking team provided 192.172.0.0/22 CIDR block for


creating AWS VPC. Which of the following AWS CLIs creates the VPC
for you using the correct CIDR block?
A. aws ec2 initiate-vpc --cidr-block 192.172.0.0/22
B. aws ec2 generate-vpc --cidr-block 192.172.0.0/22

C. aws ec2 write-vpc --cidr-block 192.172.0.0/22


D. aws ec2 create-vpc --cidr-block 192.172.0.0/22
10. The following AWS CLI command attaches a volume (vol-
9876543210fedcba0) to an instance (i-54321ab789c09876) as
/dev/xvdh,

A. True
B. False
11. As part of your disaster recovery strategy, you need to copy the
specified AMI from us-west-2 region to us-east-1 region using dry run
option. The following AWS CLI command copies the AWS AMI from
us-east1 to us-west-2.

A. False
B. True
12. Your development team wants you to create an image of an existing EC2
instance. Which AWS CLI command will achieve the image creation?
A. aws ec2 create-image --instance-id i-9876543210fedcba0
B. aws ec2 generate-image --instance-id i-9876543210fedcba0

C. aws ec2 copy-image --instance-id i-9876543210fedcba0

D. aws ec2 build-image --instance-id i-9876543210fedcba0


13. As per best practice, you would like to add Tags to your AWS AMI to
identify the environment. Which of the following AWS CLI commands
creates a Tag for AMI?
A. aws ec2 generate-tags --resources ami-67b431221 --tags
Key=ENV, Value=DEV

B. aws ec2 copy-tags --resources ami-67b431221 --tags Key=ENV,


Value=DEV
C. aws ec2 create-tags --resources ami-67b431221 --tags
Key=ENV, Value=DEV

D. aws ec2 build-tags --resources ami-67b431221 --tags Key=ENV,


Value=DEV
14. You have created a custom VPC vpc-b12217d3 and want to create a
route table for that VPC. Which of the following AWS CLI commands
creates the route table?
A. aws ec2 build-route-table --vpc-id vpc-b12217d3
B. aws ec2 generate-route-table --vpc-id vpc-b12217d3

C. aws ec2 copy-route-table --vpc-id vpc-b12217d3

D. aws ec2 create-route-table --vpc-id vpc-b12217d3


15. You created an EC2 instance with IP 55.166.46.122 using
MyEC2KeyPair.pem key-pair and you want to connect to it using an
SSH client from a Linux machine. Which of the following commands
helps you to successfully connect to your EC2 instance?
A. ssh -connect "MyEC2KeyPair.pem" ec2-user@55.166.46.122
B. ssh -attach "MyEC2KeyPair.pem" ec2-user@55.166.46.122

C. ssh -i "MyEC2KeyPair.pem" ec2-user@55.166.46.122

D. ssh -link "MyEC2KeyPair.pem" ec2-user@55.166.46.122


16. You Audit and Compliance team recommends using Least Privilege for
IAM Users. How do you achieve it?
A. By granting only the permissions required to perform a task
B. By granting everyone root access to perform a task
C. By revoking all the access from IAM Users
D. By deleting the User from IAM console
17. You want to remove the complexity out of Java coding by using
___________ for AWS services including Amazon S3, Amazon ECS,
DynamoDB, and AWS Lambda.
A. AWS SDK
B. AWS CLI
C. AWS PowerShell
D. AWS SAM Local
18. The ____________ is an open source plug-in for the Eclipse Java
integrated development environment (IDE) and it makes it easier for
developers to develop, debug, and deploy Java applications that use
AWS.
A. AWS CodeCommit
B. AWS CodePipeline
C. AWS CodeBuild
D. AWS Toolkit for Eclipse
19. The ____________ is a plug-in for the Visual Studio integrated
development environment (IDE) and it makes it easier for developers to
develop, debug, and deploy .NET applications that use AWS?
A. AWS Toolkit for Visual Studio
B. AWS CodeCommit
C. AWS CodePipeline
D. AWS CodeBuild
20. ________________ contains tasks you can use in build and release
definitions in VSTS to interact with AWS services, and it is available
through the Visual Studio Marketplace.
A. AWS CLI
B. AWS SDK
C. AWS PowerShell
D. AWS Tools for Visual Studio Team Services (VSTS)

Answers
1. A, B, C, D. You need the AWS Access Key ID, AWS Secret Access
Key, Default region name, and Default output format parameters to setup
AWS CLI.
2. A. This is the correct AWS CLI command to create the EC2 key pair.
3. B. This AWS CLI command lists all your instances and let you view
information about those EC2 instances.
4. D. This AWS PowerShell command lists your S3 bucket named my-s3-
files.
5. A. It’s the right AWS PowerShell command to delete a S3 bucket named
my-old-files.
6. D. It is the correct AWS PowerShell command that lists collection of
users in the current AWS account.
7. A. This AWS PowerShell command deletes the IAM user named Mike
from your AWS account.
8. C. AWS SAM Local CLI tool is used for the local development and
testing of Serverless applications (i.e., AWS Lambda functions).
9. D. This AWS CLI command creates a custom VPC using 192.172.0.0/22
CIDR block.
10. A. True. This AWS CLI command attaches the volume vol-
9876543210fedcba0 to the instance i- i-54321ab789c09876 as
/dev/xvdh.
11. B. True. It is the right AWS CLI command to copy the specified AMI
from us-west-2 region to us-east-1 region.
12. A. The development team can use this AWS CLI command to create an
image of an existing EC2 instance.
13. C. It is the correct AWS CLI command to add Tags to your AWS AMI to
identify the environment.
14. D. It is the AWS CLI command to create a route table for your custom
VPC vpc-b12217d3.
15. C. It is the correct way to connect to EC2 instance with IP
55.166.46.122 using MyEC2KeyPair.pem key-pair using an SSH client
from a Linux machine.
16. A. By granting only the permissions required to perform a task, you
need to find out what users need to do and then create access policies
for them that let the users perform only those tasks.
17. A. AWS SDK will remove the complexity out of Java coding for AWS
services including Amazon S3, Amazon ECS, DynamoDB, and AWS
Lambda.
18. D. AWS Toolkit for Eclipse is the plug-in for the Eclipse Java IDE.
19. A. AWS Toolkit for Visual Studio is the plug-in for the Visual Studio
IDE.
20. D. AWS Tools for Visual Studio Team Services contains tasks you can
use in build and release definitions in VSTS to interact with AWS
services.

Additional Resources
• AWS Documentation There is no place like official AWS
documentation to get the latest and correct information about all the
AWS services. Always refer to the official AWS blogs to get the latest
updates about new AWS services and update to existing features.

• AWS Command Line Interface This is a tool to control various AWS


services from the command line and also to automate them through
scripts.

• Tools to Build on AWS List of tools for developing and managing


applications on AWS using Go, Java, .Net, Node.js, Python, Ruby, etc.

• AWS Tools for PowerShell This tool helps developers and


administrators manage their AWS services and resources in Windows,
Linux, and MacOS environments.

• AWS Serverless Application Model is an open source framework,


which provides functions, APIs, databases, and event source mappings
for building serverless applications with a few lines of configuration.

• Developer Tools on AWS to code, build, test, and deploy your


applications to AWS. It also help you to automate the provisioning and
managing your infrastructure and by eliminating the need for manual
updates to avoid any manual errors.
CHAPTER 3

Networking Using Amazon Virtual


Private Cloud
In this chapter, you will learn
• Virtual Private Cloud (VPC)
• Subnets (public and private)
• Route tables
• Network access control lists (ACLs)
• Security groups
• Internet gateways
• Dynamic Host Configuration Protocol (DHCP) option sets
• Elastic Internet Protocols (IPs)
• Endpoints
• Network Address Translation (NAT) gateways
• Egress-only Internet gateways
• Peering connections
• Virtual private gateways
• Customer gateways
• Site-to-site virtual private network (VPN)
• Point-to-site VPN
• Direct connect
• Transit gateways
Welcome to the AWS networking chapter. In the last chapter we created an
AWS free account and looked at various ways of connecting to AWS
services. Then we saw how to enable multifactor authentication (MFA) for
the root account and how to secure the root account against any unauthorized
access (this will be explored in more depth in Chapter 10). The next thing we
need is a logically isolated section of AWS that you can own and control,
similar to separate networks in your on-premises datacenter. In this chapter,
we will explore the core components of Amazon Virtual Private Cloud
(VPC), and you will learn how to build your own VPC and VPN solution to
securely connect using an Internet Protocol security (IPSec) tunnel. I highly
recommend reading this chapter carefully and completing all the exercises,
because a strong knowledge of Amazon VPC, connectivity, and
troubleshooting will help you in both the real world and to pass the exam.

Amazon Virtual Private Cloud


Amazon VPC is the networking layer for Amazon Elastic Compute Cloud
(EC2) instances and enables you to launch AWS resources into an isolated
virtual network that you’ve provisioned. A VPC is a virtual network
dedicated to your IP address range, subnets, network access control lists
(NACLs), security groups, and route tables to your AWS account.
Assume you have a business with offices across the United States,
Australia, and Europe and you need to set up datacenters, which will take a
few weeks to months. You can create a VPC in each region within a few
minutes, as shown in Figure 3-1, and secure it using NACLs and security
groups.
Figure 3-1 AWS accounts and regions

Your AWS account comes with a default VPC that has a subnet in each
availability zone that is ready for you to use. If you don’t specify a subnet
when you launch an instance, the instance will be launched into your default
VPC. A VPC spans all the availability zones in a particular region, whereas
a subnet must reside entirely within one availability zone and cannot span
across zones.
You can also create your own VPC, which is called a nondefault VPC,
and configure it as you need. Any subnets that you create in your default and
nondefault VPCs are called nondefault subnets. You will not pay an
additional charge for using the Amazon VPC; however, you will pay the
standard rates for the EC2 instances and any site-to-site VPN connection and
Network Address Translation (NAT) gateway.
Amazon VPC has been validated as being compliant with the Payment
Card Industry (PCI) Data Security Standard (DSS) and supports the
processing, storage, and transmission of credit card data by a merchant or
service provider.
There are soft limits (which can be increased by submitting a request to
AWS, e.g., on the Amazon VPC limit form) and hard limits (which can’t be
changed) to the number of Amazon VPCs and the components you can
provision. You start with a default limit of five VPCs per region. There is a
limit of 200 subnets per VPC. The limit for IPv4 is five IPv4 Classless Inter-
Domain Routing (CIDR) blocks per VPC, and this comprises your primary
CIDR block plus four secondary CIDR blocks. The limit for IPv6 is one IPv6
CIDR block per VPC, and this limit cannot be increased. These limits change
over time so please refer to
https://docs.aws.amazon.com/general/latest/gr/aws_service_limits.html for
the latest AWS service limits.

Subnets
As mentioned, a VPC spans all the availability zones in a particular region,
whereas a subnet must reside entirely within one availability zone and cannot
span across them. You can add one or more subnets to each availability zone
after creating the VPC. You can specify the CIDR block for the subnet when
you create it, which should be a subset of the VPC CIDR block. You can
protect your applications from failure by launching instances in separate
availability zones, which are engineered to be isolated from failures in other
availability zones.
You can assign IPv6 CIDR blocks to your subnets by assigning an IPv6
CIDR block to your VPC. A VPN connection enables you to communicate
with your corporate network, and an Internet gateway enables communication
over the Internet.

Public Subnet
A subnet is called public when its traffic is routed to an Internet gateway.
Your instance must have a public IPv4 address or an elastic IP address
(IPv4), which is a static public IPv4 address assigned by AWS, if it needs to
communicate with the Internet over IPv4. Your instance must have an IPv6
address if it needs to communicate with the Internet over IPv6.

Private Subnet
A subnet is called private when it doesn’t have a route to the Internet
gateway. The internal IPv4 address range of the subnet is always private,
regardless of the type of subnet, and AWS does not announce this address
block to the Internet.

Route Tables
A route table has a set of rules that are used to determine where network
traffic is directed. All your subnets in a VPC must be associated with a route
table because this table controls the routing for the subnet. You can associate
multiple subnets with the same route table; however, a single subnet can only
be associated with one route table at any point in time.
A primary or main route table is created automatically with your VPC
where you can add, remove, and modify routes based on your need. You can
also create custom route tables for your VPC if required. Your subnet is
implicitly associated with the primary route table if you don’t explicitly
associate a subnet with any particular custom route table. The main route
table controls the routing for all your subnets that are not explicitly
associated with any other custom route table.
You cannot delete the main route table, and each route in a table specifies
a destination CIDR and a target. AWS uses the most specific route that
matches the traffic and determines how to route it. You must update the route
table for any subnet that uses a virtual private gateway, an Internet gateway,
an egress-only Internet gateway, a peering connection, a NAT device, or a
VPC endpoint in your VPC. You can have 200 route tables per VPC, and this
limit includes the main route table. You can add 50 nonpropagated routes per
route table, and you can increase this limit up to a maximum of 1,000 if
required. You can add 100 Border Gateway Protocol (BGP)–advertised
propagated routes per route table, but this limit cannot be increased.

Network Access Control Lists


The VPC provides another layer of security by acting as a firewall for
controlling traffic in and out of one or more subnets. The default VPC
automatically comes with a modifiable default NACL, and it allows all
inbound and outbound IPv4 and IPv6 traffic, if applicable. You can add or
remove rules from the default NACL or create additional custom NACLs for
your VPC. The changes are automatically applied to the subnets to which
NACL is associated with when you add or remove rules from a network
ACL.
All the subnets in your VPC must be associated with a NACL. Your
subnet is automatically associated with the default NACL if you don’t
configure it otherwise. A subnet can be associated with only one NACL at a
time, but you can associate a NACL with multiple subnets. The previous
association is removed when you associate a new NACL with a subnet.
NACLs are stateless, so the inbound traffic allowed is subject to the
rules for outbound traffic (and vice versa). A NACL contains a number of
rules, and AWS evaluates them in an order from lowest to highest to decide
whether traffic is allowed to and from the associated subnet. The highest
number you can use for NACLs rules is 32766, and AWS recommends
creating rules in increments to make it easy to add any new future rules that
you may need later on.

Security Groups
A security group acts as another virtual firewall at the instance level that
controls the inbound and outbound traffic. You can assign up to five security
groups to the instance when you launch it in a VPC. NACLs act at the subnet
level, and security groups act at the instance level. You can assign a different
set of security groups to each instance in a subnet of your VPC. Your security
group name must be unique within the VPC.

EXAM TIP You don’t have to add a rule to allow your instances to
communicate with each other. If you use the default security group, it
automatically allows communication; but you must add a rule to allow this if
you use anything other than the security group.

You can add rules that control the inbound traffic to instances for each
security group and add a separate set of rules that control the outbound
traffic. The default number of security groups per region limit is 2,500 and
the maximum limit is 10,000. The default security group rule limit is 60 for
inbound and 60 for outbound per security group—for example, a security
group can have 60 inbound rules for IPv4 traffic and 60 inbound rules for
IPv6 traffic.
TIP If you use ::/0 in your security group for IPv6, then you are enabling all
IP addresses over the Internet to access your instance using Secure Shell
(SSH) or Remote Desktop Protocol (RDP). This is acceptable only for your
learning proof of concept (POC) or testing purpose, but it’s unsafe and not a
best practice in enterprise production environments. In a production
environment, you’ll authorize only a specific IP address or range of
addresses to access your instance.

In a security group, you can only allow rules—you cannot not deny rules.
You can specify separate rules for inbound traffic and another rule for
outbound traffic. You can create a security group with no inbound rules, in
which case the inbound traffic originating from another host to your instance
will not be allowed until you explicitly add inbound rules to the security
group. In the same way, if your security group has no outbound rules, no
outbound traffic originating from your instance is allowed.
Security groups are stateful, which means that when you send a request
from your instance, the return response traffic for that request is allowed to
flow back to the instance, regardless of your inbound security group rules. In
the same way, the responses to the inbound traffic are allowed to flow out,
regardless of your outbound rules.

TIP If you use 0.0.0.0/0 in your security group for IPv4, you are enabling
all IP addresses over the Internet to access your instance using SSH or RDP.
This is acceptable only for your learning POC or testing purpose; it’s unsafe
and not a best practice in enterprise production environments. In a
production environment, you’ll authorize only a specific IP address or range
of addresses or a single IP address /32 to access your instance.

Internet Gateways
An Internet gateway is a highly available, redundant, and horizontally scaled
VPC component that allows communication between the Internet and
instances in your VPC. It doesn’t impose bandwidth constraints or any
availability risks on your network traffic. It serves two purposes: to perform
NAT for instances that have not been assigned public IPv4 addresses and to
provide a target in your VPC route tables for Internet-routable traffic,
including IPv4 and IPv6 traffic.
You need to make sure that your NACL and security group rules allow the
relevant traffic to flow to and from the Internet for instances in a VPC subnet.
You need to attach an Internet gateway to a VPC and make sure that the
subnet’s route table points to it. Also make sure that instances in your subnet
have a globally unique IP address (elastic IP address, public IPv4 address,
or IPv6 address).
A subnet is called public when associated with a route table that has a
route to an Internet gateway. Your instance must have a public IPv4 address
or an elastic IP address that’s associated with a private IPv4 address if you
want to enable communication over the Internet for IPv4. Your VPC and
subnet must have an associated IPv6 CIDR block, and your instance must be
assigned an IPv6 address from the range of the subnet. IPv6 addresses are
globally unique and are public by default if you want to enable
communication over the Internet for IPv6.

Dynamic Host Configuration Protocol Option Sets


The options field of a Dynamic Host Configuration Protocol (DHCP)
message contains configuration parameters like domain name, domain name
server, and the NetBIOS node type, and it provides a standard for sending
configuration details to hosts on the TCP/IP network.
The DHCP options sets can be configured for your VPC. The Amazon
EC2 instances that you launch into a nondefault VPC are private by default.
Unless you specifically assign a public IPv4 address during launch, they’re
not assigned, or you need to modify the subnet’s public IPv4 address
attribute. By default, AWS assigns an unresolvable hostname like ip-10-10-
10-101 to all instances in any nondefault VPC. You can define your own
domain name for your instances, and you must specify a special set of DHCP
options to use with the VPC.
The IP addresses default to Amazon-provided DNS, or you can set up
custom domain name servers, with the names separated by commas. You must
set domain name servers to a custom DNS server if you want your instance to
receive a custom DNS hostname, as specified in the domain name. After you
attach the DHCP options with a VPC, both existing and new instances that
you launch automatically pick up the changes within a few hours, depending
on the current frequency with which the DHCP lease is renewed. You don’t
need to restart or relaunch the instances. If required, you can explicitly renew
the lease using the operating system on that instance.
You can’t modify the DHCP options after you create them. If required,
you can set up your VPC to use no DHCP options at all. You can associate
only one set of DHCP options with a VPC. The DHCP option is
disassociated from the VPC when you delete it.

NOTE Your default VPC automatically has a set of DHCP options with the
Amazon-provided DNS server domain-nameservers=AmazonProvidedDNS
that allows any public subnets in your VPC to communicate with the Internet
over an Internet gateway.

Elastic Internet Protocols


An elastic Internet Protocol (IP) address is a public static address that you
can associate with an instance or network interface for any of your account
VPCs. When you associate the elastic IP address with the network interface
instead of directly associating it with an instance, you can move all the
attributes of the network interface from one instance to another instance
easily. AWS currently supports only IPv4 addresses and not IPv6 elastic IP
addresses. Elastic IP address can be assigned to only one instance at a time.
You can associate an elastic IP address with an instance, and it updates the
network interface attached to it.
The elastic IP address can be moved from one instance to another either
within the same VPC or another VPC. Until you explicitly release your
elastic IP address, it remains associated with your AWS account. AWS
charges for elastic IP addresses that are not associated with a running
instance, that are stopped, or that are not attached to any network interface.
You are not charged for an elastic IP address when the associated instance is
running. As mentioned, you are limited to five elastic IP addresses, but you
can increase this amount by creating a ticket with AWS. You can tag an
elastic IP address; however, tags are not recovered when you recover an
elastic IP address.
You are allowed to bring part or all of your public IPv4 address range
from your on-premises network to your AWS account. Bring your own IP
(BYOIP) enables you to move all or part of your existing publicly routable
IPv4 address space to AWS. You will continue to own that IP range, but
AWS will advertise it on the Internet. You can create elastic IPs from the IP
space you bring to AWS and use them with your EC2 instances, network load
balancers, and NAT gateways. You will continue to have access to AWS
elastic IPs, so you can choose to use BYOIP elastic IPs, Amazon-supplied
IPs, or both.

EXAM TIP If you want your instance to be accessible via an IPv4 address
over the Internet, SSH, or RDP, you must associate an elastic IP address
(i.e., a static public IPv4 address) to your instance, and you must configure
your security group rules to allow access over IPv4.

Endpoints
VPC endpoint services powered by the Private Link service do not require
an Internet gateway, NAT device, VPN connection, or AWS Direct Connect
connection, and they enable you to privately connect your VPC to supported
AWS services. When you use the VPC endpoint, your instances do not
require public IP addresses to communicate with other resources and the
traffic does not leave the Amazon network.
Endpoints are virtual devices that are highly available, redundant, and
horizontally scaled VPC components. Without imposing the availability risks
or bandwidth constraints on your network traffic, they allow communication
between instances in your VPC and various services. Interface endpoints and
gateway endpoints are the two types of VPC endpoints that you can create.

Interface Endpoints
An interface endpoint is an elastic network interface that is powered by AWS
Private Link with a private IP address that serves as an entry point for traffic
destined to a supported service. The following services are supported
interface endpoints:
• AWS CloudFormation
• Amazon API Gateway
• AWS CloudTrail
• Amazon CloudWatch
• Amazon CloudWatch Events
• Amazon CloudWatch Logs
• AWS CodePipeline
• AWS CodeBuild
• AWS Config
• AWS CodeCommit
• Amazon EC2 API
• Elastic Load Balancing
• Amazon Elastic Container Service
• Amazon Elastic Container Registry
• AWS Key Management Service
• Amazon Kinesis Data Streams
• Amazon Kinesis Data Firehose
• Amazon SageMaker and Amazon SageMaker Runtime
• Amazon SageMaker Notebook Instance
• AWS Secrets Manager
• AWS Security Token Service
• AWS Service Catalog
• Amazon SQS
• Amazon SNS
• AWS Systems Manager
• AWS Transfer for SFTP
• Endpoint services hosted by other AWS accounts
• Supported AWS Marketplace partner services

Gateway Endpoints
A gateway endpoint is the target of a specified route in your route table that
is used for traffic destined to any supported AWS service. The following
AWS services are supported:
• DynamoDB
• Amazon S3

Controlling the Use of VPC Endpoints


You need to create an AWS Identity and Access Management (IAM) user
policy that grants users the required permissions to create, modify, describe,
and delete endpoints because IAM users do not have permission to work
with any endpoints by default. Here is an example of the IAM policy:

Network Address Translation Devices


If you want to enable instances in a private subnet to connect to the Internet
but prevent the Internet from initiating connections with the instances, you
need a NAT device. It forwards traffic from the instances in the private
subnet to the Internet and then sends the response back to the instances. The
source IPv4 address is replaced with the NAT device’s address when traffic
goes to the Internet, and the NAT device translates the address back to the
instances’ private IPv4 addresses when the response traffic is coming
through.
You need to use an egress-only Internet gateway instead of NAT devices
for IPv6 traffic because NAT devices are not configured for IPv6 traffic.
AWS supports two kinds of NAT devices: NAT gateways and NAT instances.
AWS recommends using NAT gateways over NAT instances, since the NAT
gateway provides better availability and bandwidth. The NAT gateway
service is offered as a managed service, so it does not require any
administration efforts from you. You may need to choose a NAT instance for
specific purposes, and it is launched from a NAT Amazon Machine Image
(AMI).

NAT Gateways
A NAT gateway is charged in terms of hourly usage and data processing
rates. You must specify the public subnet to create a NAT gateway and
specify an elastic IP address to associate with it. You then need to update the
route table, which is associated with one or more of your private subnets, to
point Internet-bound traffic to the NAT gateway to enable the instances in
your private subnets to communicate with the Internet.
If you attach a single NAT gateway to multiple private subnets, this will
affect other subnets when the availability zone of the NAT gateway is down.
So, if you want to create an availability zone–independent architecture, to
avoid failure, you need to create a NAT gateway in each availability zone
and configure the routing to ensure that your resources in private subnets use
the NAT gateway in the same availability zone.
A NAT gateway bandwidth is 5 Gbps and automatically scales up to 45
Gbps as required. You can distribute the workload by splitting your
resources into multiple subnets if you require more bandwidth and create a
NAT gateway in each subnet. A NAT gateway supports Internet Control
Message Protocol (ICMP), Transmission Control Protocol (TCP), and User
Datagram Protocol (UDP) and uses ports from 1024 to 65535. A NAT
gateway supports up to 55,000 simultaneous connections to each unique
destination. You cannot associate a security group with a NAT gateway, but
you can use a NACL to control the traffic to and from the subnet in which the
NAT gateway is attached.
CAUTION You will be charged for creating and using a NAT gateway in
your AWS account. It has hourly usage and data processing charges in
addition to the Amazon EC2 charges for data transfer, so use caution when
creating the NAT gateway and terminate it when you don’t need it anymore.

NAT Instances
You need to create your NAT instance in a public subnet to enable instances
in the private subnet to initiate outbound IPv4 traffic to the Internet but at the
same time prevent the instances from receiving inbound traffic initiated by
someone on the Internet. Amazon offers the Amazon Linux AMI, which is
configured to run as a NAT instance. You can search for them in the Amazon
EC2 console—they include the string amzn-ami-vpc-nat in their name.

Egress-Only Internet Gateways


An egress-only Internet gateway is a highly available, redundant, and
horizontally scaled VPC component. It allows outbound communication over
IPv6 from instances from your VPC to the Internet, and it prevents the Internet
from initiating an IPv6 connection with your instances.
IPv6 addresses are public by default and globally unique. You need to
add a route to your route table that points a specific range of IPv6 address or
all IPv6 traffic (::/0) to the egress-only Internet gateway.
An egress-only Internet gateway is stateful, which means it forwards
IPV6 traffic from the instances in the subnet to the Internet and then sends
back the responses to the instances. NACL can be used to control the traffic
to and from the subnet for which the egress-only Internet gateway routes the
IPV6 traffic.

Peering Connections
A VPC peering connection routes the traffic between two VPCs privately,
where instances in both VPCs can communicate with each other as if they are
in the same network. You can create a VPC peering connection between your
own VPCs or with a VPC in another AWS account, or with a VPC in a
different AWS region. AWS does not use a gateway or a site-to-site VPN
connection and does not rely on a separate piece of physical hardware to
create a VPC peering connection, so there is no bandwidth bottleneck or a
single point of failure in terms of communication.
A VPC peering connection makes it easy to transfer data between your
EC2 instances, Amazon Relational Database Service (RDS) databases, and
AWS Lambda functions that run in different AWS regions using private IP
addresses, without requiring a separate network appliance, gateway, or VPN
connections. The peering connection traffic always stays on the global AWS
backbone and never traverses the public Internet, which reduces threats such
as DDoS attacks and other common exploits. The inter-region VPC peering
connection provides a cost-effective and simple way to share resources
between regions and makes it easy to replicate data in cases of geographic
redundancy.

Virtual Private Gateways


A virtual private gateway is a VPN concentrator on the AWS side. If you
want to configure a site-to-site VPN connection, you need create a virtual
private gateway and attach it to your VPC. You also need to specify the
private autonomous system number (ASN) for the gateway—the default ASN
is 64512. The ASN cannot be changed after creating the virtual private
gateway.

EXAM TIP The instances that you created in the VPN-only subnet can’t
reach the Internet directly, so any Internet-bound traffic must first traverse
the virtual private gateway to your network. From here, the traffic goes
through your firewall using corporate security policies. The traffic from your
network going to an elastic IP address for an instance in the public subnet
goes over the Internet and not over your virtual private gateway. As a result,
you need to set up the route table and security group rules to enable the
traffic to come from your network over the virtual private gateway to the
public subnet.

Customer Gateways
A customer gateway is a software application or physical device on your
side of the site-to-site VPN connection, which you must create and which
provides information to AWS about the customer gateway device. You’ll
need an Internet-routable IP address (the public IP address value must be
static) and static or dynamic routing to create a customer gateway resource.
You can use an existing ASN assigned to your network, or you can use a
private ASN (in the 64512 to 65534 range). AWS automatically uses 65000
as the ASN if you use the VPC wizard in the console to set up your VPC.
The virtual private gateway is not the initiator, so the client customer
gateway must initiate the traffic to the tunnels. The VPN tunnel comes up only
when traffic is generated from the client side of the site-to-site VPN
connection. The VPN tunnel may go down if your connection experiences
idle time for a certain period (depending on your configuration), so you may
need to use a network monitoring tool to generate keep-alive pings to prevent
this.

Site-to-Site Virtual Private Network


The instances in your VPC by default can’t communicate with your own
(remote/on-premises) network. You need to attach a virtual private gateway,
create a custom route table, update your security group rules, and create a
site-to-site (S2S) VPN connection to enable access to your on-premises
network from your VPC. The AWS site-to-site VPN currently does not
support IPv6 traffic connection but does support IPSec VPN connections.

Point-to-Site Virtual Private Network


You need a point-to-site (P2S) VPN gateway connection if you want to
securely access the instances in your VPC from either your laptop or from a
client computer. You can establish a P2S connection by starting it from your
computer. This solution is useful for anyone who has had to connect to the
instances in the AWS VPC from a remote location, like from home or from a
conference room or from another public location. When you have only a few
clients that need to connect to a VPC, P2S VPN is a useful solution to use
instead of S2S VPN.

NOTE The steps to create the point-to-site VPN connection are in the
“Additional Resources” section.

Direct Connect
AWS Direct Connect uses a standard Ethernet fiber-optic cable to link your
internal network to an AWS Direct Connect location. You will be connecting
one end of the cable to your router and the other end to an AWS Direct
Connect router. You can create a public virtual interface to access public
services, like Amazon S3, and a private virtual interface to access your VPC,
bypassing the Internet service providers (ISPs) in your network.
You will be using single-mode fiber with a 1000BASE-LX (1310 nm)
transceiver for 1 gigabit Ethernet or a 10GBASE-LR (1310 nm) transceiver
for 10 gigabit Ethernet and work with an AWS Direct Connect partner to
create a dedicated 1 Gbps or 10 Gbps connection. Auto-negotiation for the
port must be disabled, and the port speed, along with full-duplex mode, must
be configured manually. Your connection, including intermediate devices,
must support 802.1Q virtual area network (VLAN) encapsulation. Your
device must support the Border Gateway Protocol (BGP) and BGP MD5
authentication. You can also get hosted connections of 50 Mbps, 100 Mbps,
200 Mbps, 300 Mbps, 400 Mbps, 500 Mbps, 1 Gbps, 2 Gbps, 5 Gbps, and
10 Gbps through working with an independent service provider who is an
AWS Direct Connect partner. AWS Direct Connect supports both IPv4 and
IPv6 communication protocols, and the IPv6 addresses are accessible
through AWS Direct Connect public virtual interfaces.

Transit Gateways
In order to connect your VPC and on-premises networks, you need a transit
gateway, which is a network transit hub. You can attach a VPN connection, an
AWS Direct Connect gateway, or a VPC to a transit gateway. It has a default
route table that includes dynamic and static routes, and it decides the next
hop based on the destination IP address of the packet.
You must create static routes to peer two transit gateways and route
traffic between them. The routes are propagated from the transit gateway to
your on-premises router using BGP in the VPN connection. The following
are some use cases of a transit gateway.

Centralized Router
The transit gateway can be configured as a centralized router that connects
all of your VPCs and VPN connections. In this use case, all the attachments
can route packets to each other, and the transit gateway serves as a simple
layer 3 IP hub.

Isolated Routers
The transit gateway can be configured as multiple isolated routers, similar to
using multiple transit gateways. This provides more flexibility in scenarios
where the routes and attachments might change. In this use case, each isolated
router has a single route table, so it cannot route packets to or receive
packets from the attachments for another isolated router, but the attachments
associated with one isolated router can route packets to each other.

Edge Consolidator
The transit gateway can be configured to route packets to one or more VPN
connections but your VPCs cannot route packets to each other. In this use
case, you can create a route table for the VPN connections and a route table
for the VPCs.

Chapter Review
This chapter introduced the AWS Virtual Private Cloud (VPC) and its
components. VPC is the networking layer that enables you to launch AWS
resources into a logically isolated virtual network. A VPC subnet resides
entirely within one availability zone and cannot span across zones. A subnet
is called public when its traffic is routed to an Internet gateway, and it is
called private when it doesn’t have a route to the Internet gateway. A route
table has a set of rules that are used to determine where network traffic is
directed. The route table controls the routing for the subnet, so all your
subnets in a VPC must be associated with a route table. You can add another
layer of security using a network access control list to your VPC, which acts
as a firewall controlling traffic in and out of one or more subnets by allowing
all the inbound and outbound IPv4 traffic and, if applicable, IPv6 traffic.
Security groups act at the instance level, and NACLs act at the subnet level.
A different set of security groups can be assigned to each instance in a subnet
of your VPC. An Internet gateway allows communication between the
Internet and instances in your VPC. It performs network address translation
(NAT) for instances that have not been assigned public IPv4 addresses and
also provides a target in your VPC route tables for Internet-routable traffic.
The options field of a Dynamic Host Configuration Protocol (DHCP)
message contains the configuration parameters and provides a standard for
sending configuration details to hosts on the TCP/IP network. An elastic IP
address is a public static address that you will be able to associate with an
instance or network interface for any of your account VPCs.
A VPC endpoint service is powered by Private Link, and it enables you
to privately connect your VPC to supported AWS services using the Amazon
network. A NAT device is used to enable instances in a private subnet to
connect to the Internet but prevents the Internet from initiating connections
with the instances. An egress-only Internet gateway allows outbound
communication over IPv6 from instances from your VPC to the Internet, and
it prevents the Internet from initiating an IPv6 connection with your instances.
A VPC peering connection routes the traffic between your own VPCs or with
a VPC in another AWS account, or with a VPC in a different AWS region
privately, where instances in both VPCs can communicate with each other as
if they are in the same network. A virtual private gateway is a VPN
concentrator attached to your VPC on the AWS side. A customer gateway is a
software application or physical device on the client side of the site-to-site
VPN connection that provides information to AWS about your customer
gateway device. A site-to-site VPN connection allows access to your on-
premises network from your VPC using Internet Protocol security (IPSec). A
point-to-site (P2S) VPN gateway connection allows access to the instances
in your VPC from your individual laptop or from a client computer. AWS
Direct Connect uses a standard Ethernet fiber-optic cable to link your
internal network to an AWS Direct Connect location. You connect one end of
the cable to your router and the other end to an AWS Direct Connect router.
AWS Direct Connect allows you to use a dedicated private network
connection between your on-premises network and one of the AWS Direct
Connect locations. A transit gateway is a network transit hub that you can
attach to a VPN connection, an AWS Direct Connect gateway, or a VPC.

Exercises
The following exercises will help you practice creating a VPC and related
services. You need to create an AWS account, as explained earlier in this
chapter, in order to perform the exercises. You can use the Free Tier when
launching AWS resources, but make sure to terminate this at the end.

Exercise 3-1: Create a VPC Using the AWS Management


Console
Let’s jump into action and create a custom VPC with an IPv4 CIDR block.
You can use the Amazon VPC wizard in the Amazon VPC console to create a
VPC. The wizard creates a VPC with a /16 IPv4 CIDR block, which creates
65,536 private IP addresses with a /24 public subnet with 256 public IP
addresses, as well as a /24 private subnet with 256 private IP addresses. It
also attaches an Internet gateway to the VPC. It then creates a custom route
table and associates it with your subnets so that traffic can flow between the
subnet and the Internet gateway.
1. First log in to your AWS account by entering your AWS account
username and password, and you will see the AWS Management
Console page.
2. You can access all AWS services from this main AWS console page.
You can search for a particular service below Find Services or select
from Recently Visited Services if you used that service before, or you
can go to All Services and select from the list of services. Use one of
the methods to select VPC, and you will be directed to the VPC console
page.
3. This VPC dashboard page will list all the VPC resources that you are
currently using in this region, and you can navigate to them by selecting
from the list. You can either create a VPC manually or use the VPC
wizard, which takes care of the related services and provides them for
you. I recommend using the VPC wizard for beginners and manual VPC
creation for experienced users. We are going to create our first VPC
using the VPC wizard, so select Launch VPC Wizard from the VPC
dashboard and it will take us to the main page of VPC wizard.
4. We are going to select the second option from the left pane, as you did
in the first step, to create another VPC with one Public subnet and one
Private subnet.

5. In the next step, you can provide the CIDR range for VPC, Name, Public
and Private Subnet CIDR, and Availability Zone (if required) and attach
an elastic IP.
6. After verifying all the details, click the Create VPC button. All the
related services that you need for a VPC are created.

7. From the VPC console, select Your VPCs from the menu on the left, and
here you can see all the details about the VPC in the Description tab.

8. Select Subnets from the VPC console, and you will see the list of
subnets in your AWS account. Select Private Subnet, and you can see
251 available IP addresses because AWS reserves 5 IP addresses from
the total 256 IP addresses.
9. You can select My Public Subnet, as shown here, and you can see
Subnet ID, Availability Zone, Network ACL, Route Table, and other
details.
10. Now select Route Tables from the list and see the subnet’s associated
details.

11. Select the next route table in the list.


12. Select Internet Gateways from the list, which are attached to the VPC.

13. Select DHCP Option Sets from the list on the left side of your VPC
console, and you will see the default option set provided by AWS.

14. Select Elastic IPs.


15. Select NAT Gateways from the list.

16. Select Network ACL from the list, and you can see the inbound and
outbound rules.
17. Select the Inbound Rules tab to see these rules.

18. Select the Outbound Rules tab to see those rules.


19. Select the Subnet Associations tab in the Network ACL, as shown here:

20. The VPC architecture diagram shows all the VPC and subnet details.
Exercise 3-2: Add a Subnet to Your VPC Using the AWS
Management Console
The following steps explain how to add a new private or public subnet to
your existing VPC.
1. Open the Amazon VPC console using the link
https://console.aws.amazon.com/vpc/.
2. Choose Subnets and then Create Subnet from the navigation pane.
3. You need to provide the Name tag, which is a name for your subnet. It
creates a tag with a key of name and the value of subnet-name.
4. Then you need to choose the VPC for which you’re creating the subnet.
5. You can choose an availability zone or leave the default No Preference
selected to let AWS choose it for you.
6. Then specify an IPv4 CIDR block for your subnet, like 10.0.10.0/23.
7. Verify all the input values and then choose Create Subnet.
8. This will be a private subnet if you don’t attach an Internet gateway to
it, and it will be a public subnet when you attach an Internet gateway to
it.

Questions
The following questions will help you gauge your understanding of the VPC
and the components explained in this chapter. Read all the answers carefully
because there might be more than one correct answer. Choose the best
responses for each question.
1. Your client decided to move to AWS and asked you define the logically
isolated virtual network in AWS using the predefined IP address range.
Which of the following will you need to create to accomplish this?
A. Public subnet
B. Private subnet
C. Virtual private cloud
D. NAT gateway
2. You created the VPC using the given range of the CIDR block by your
network team. However, your application become so popular that you
need to add new features, high availability, and redundancy; your AWS
architect asked you to increase the size of VPC. Is it possible to resize
it?
A. Yes, it can be extended by adding four secondary IPV4 CIDR blocks.
B. No, it is not possible to resize IPv4 CIDR blocks, but you can resize
IPv6 CIDR blocks.
C. No, it is not possible to resize the VPC.
D. Yes, it is possible to increase the size of VPC, but you cannot reduce
it.
3. You are designing your AWS network and need to create the largest
VPC and smallest VPC based on your application requirements. What
are the largest and smallest IPv4 VPCs that you are allowed to create in
AWS?
A. Largest /16 and smallest /30
B. Largest /8 and smallest /32
C. Largest /56 and smallest /64
D. Largest /16 and smallest /28
4. A user has created a VPC with one public subnet and one private
subnet. The user wants to run the patch updates for the instances in the
private subnet, but the instances are not able to connect to the Internet.
How can the instances from the user’s private subnet connect to the
Internet?
A. Attach the Internet Gateway to the private subnet
B. Allow inbound traffic for port 80 to allow Internet updates in the
security group
C. Use a NAT gateway or NAT instance with an elastic IP
D. The instance on the private subnet can never connect to the Internet
5. You client asked you to automatically provision the VPC and all its
related components quickly, so you decided to use the VPC wizard in
the AWS Management VPC console. What options are provided for you
by default in the VPC wizard? (Choose all that apply.)
A. Amazon VPC with a single public subnet only
B. Amazon VPC with public and private subnets
C. Amazon VPC with public and private subnets and AWS site-to-site
VPN access
D. Amazon VPC with a private subnet only and AWS site-to-site VPN
access
6. VPC endpoints allow you to privately connect to your services from
those hosted on the AWS VPC without requiring an Internet gateway, a
NAT device, or VPN connection. What two types of endpoints are
available in Amazon VPC? (Choose two.)
A. Site-to-site endpoints
B. Gateway endpoints
C. Interface endpoints
D. Point-to-site endpoints
7. Security groups in a VPC operate at the instance level, where you
specify which traffic is allowed to or from an Amazon EC2 instance.
NACLs operate at the subnet level and evaluate all the traffic entering
and exiting a subnet. Which of the following is not true?
A. Security groups can be used to set both allow and deny rules.
B. NACLs do not filter traffic between instances in the same subnet.
C. NACLs perform stateless filtering, while security groups perform
stateful filtering.
D. NACLs can be used to set both allow and deny rules.
8. True or False: Transitive peering relationships are supported in Amazon
VPC peering. For example, if I peer VPC X to VPC Y and I peer VPC Y
to VPC Z, does that mean VPCs X and Z are peered?
A. True
B. False
9. Which of the following is false about elastic IP address pricing?
A. You will not incur costs when the elastic IP address is associated
with a running EC2 instance.
B. You will not incur costs when the elastic IP address is associated
with a stopped EC2 instance.
C. You will not incur costs when the IP address is from a BYOIP
address pool.
D. You will not incur costs when the instance has only one elastic IP
address attached to it.
10. A user has created a VPC with two public subnets and three security
groups. The user has launched an instance in a public subnet and
attached an elastic IP. He is still unable to connect to that EC2 instance.
The Internet gateway has also been created. What could be the reason
for the connection error?
A. The Internet gateway is not configured with the route table to route
traffic
B. The private IP is not present for the instance
C. Outbound traffic is disabled on the security group
D. Traffic is denied on the security group

Answers
1. C. VPC logically isolates the virtual network in AWS using the
predefined IP address range.
2. A. Yes, the VPC can be extended by adding four secondary IPV4 CIDR
blocks, and you can decrease your VPC by deleting those secondary
CIDR blocks. However, you cannot change the size of the IPv6 address
range of your VPC.
3. D. AWS VPCs can vary in size from 16 addresses (/28 netmask), which
is the smallest, to 65,536 addresses (/16 netmask), which is the largest.
4. C. You need to use a NAT device (NAT gateway or NAT instance) to
enable instances in a private subnet to connect to the Internet to do
patching and software updates but it prevents the incoming traffic
initiated from Internet with these instances.
5. A, B, C, D. You can create four types of VPCs using the VPC wizard:
Amazon VPC with a single public subnet only, Amazon VPC with
public and private subnets, Amazon VPC with public and private
subnets and AWS site-to-site VPN access, and Amazon VPC with a
private subnet only and AWS site-to-site VPN access.
6. B, C. Amazon VPC offers two types of endpoints: gateway endpoints
and interface endpoints. Endpoints allow you to privately connect your
VPC to your services hosted on AWS without requiring an Internet
gateway, NAT device, or VPN connection.
7. A. Security groups can be used to set only allow rules, not deny rules;
however, network ACLs can be used to set both allow and deny rules.
8. B. No, transitive peering relationships are not supported in AWS.
9. B. False. You will incur costs when the elastic IP address is associated
with a stopped EC2 instance.
10. A. You need to configure the Internet gateway with the route table to
route traffic and then the user will be able to connect to the EC2
instance.
Additional Resources
• AWS Documentation/Blogs There is no place like official AWS
documentation to get the latest and most up-to-date information about all
the AWS services and features.

• VPC Sharing Share subnets with other AWS accounts by decoupling


accounts and networks within the same AWS organization. This blog
explains in detail how to configure VPC sharing.

• AWS Transit Gateway Migration The AWS Transit Gateway is


similar to a transit VPC where you can attach up to 5,000 VPCs and
attach your AWS VPN connections. This blog explains transit gateway
migration steps from your existing transit VPC solution to the AWS
Transit Gateway service.

• AWS Client VPN Setup This is a fully managed service that provides
the ability to securely access AWS and on-premises resources from any
location using OpenVPN–based clients. This blog explains in detail how
to configure client VPN setup.

• OpenVPN Setup This is a secure, open-source OpenVPN service, and


this blog explains in detail how to deploy it using Amazon VPC and test
some functionality.

• Debug Network Connectivity of Amazon VPC It is crucial to


monitor the health and impact on performance, including latency and
percentage of packet loss, across your network connectivity. This blog
explains in detail how to configure AWSSupport-
SetupIPMonitoringFromVPC to monitor these metrics.
CHAPTER 4

Creating a Virtual Machine Using


Amazon EC2
In this chapter, you will learn
• What is EC2?
• Amazon Machine Image (AMI)
• Tenancy options
• Instance types
• Pricing model for EC2
• EC2 instance virtualization types
• Storage options for Amazon EC2
• EC2 instance lifecycle
• Generating security keys
• Launching an Amazon EC2
• Security groups that protect instances
• Best practices for Amazon EC2

This chapter will explain how Amazon Elastic Compute Cloud (Amazon
EC2) provides scalable, secure, and resizable elastic compute capacity in
the cloud and how it is designed to make web-scale cloud computing easier
for developers.
Elastic Compute Cloud
Amazon EC2 is a simple web service interface that allows you to obtain and
boot new server instances in minutes. It allows you to quickly scale up and
down to the required capacity whenever there is a spike or dip in your
computing requirements, which reduces your need to forecast traffic. Amazon
EC2 saves the cost of computing by allowing you to pay only for capacity
that you actually use. You don’t need to invest in hardware up-front, which
allows you to develop and deploy applications faster. You can configure
security, networking, and manage storage, and use EC2 to launch as many or
as few virtual servers based on your need.

EXAM TIP You need to know the basics of launching an Amazon EC2
instance. In order to launch an instance, you must specify an AMI, which
defines the software on the instance at launch, and an instance type, which
defines the virtual hardware supporting the instance (memory, CPUs,
storage, etc.).

Amazon Machine Image


An Amazon Machine Image (AMI) is a machine template that provides the
information required to launch a new instance. You must specify an AMI
when you launch an instance, and you can launch multiple instances from a
single AMI. The AMI can be one or more Amazon Elastic Block Store
(Amazon EBS) snapshots, instance store–backed AMIs, or a template for the
root volume of the instance. AWS controls which account can use the AMI to
launch instances based on permissions. When an AMI is launched, a block
device mapping specifies the list of volumes that need to be attached to the
instance.
As shown in Figure 4-1, you can launch instances from an AMI if either
you created the AMI or the owner granted you launch permissions. You need
to register an AMI after creating it before you can launch new instances. The
AMI can be copied between regions or different AWS accounts. You can
deregister the AMI when you no longer require it.

Figure 4-1 AMI lifecycle

You can search for an AMI based on the criteria provided by AWS or
from community AMIs or from the AWS Marketplace. As soon as you create
an instance from an AMI, you can connect to it and use it just like you would
any other server.

Bundle Tasks
A Windows instance can be bundled in order to create a Windows instance
store–backed AMI. It can be used to create bundles of Amazon instances, and
you need to register these bundles as AMIs before launching new instances.

Root Device Types


The root device volume contains the image that will be used to boot when
you launch an instance. When AWS introduced EC2, all AMIs were backed
by the instance store. That means the root device is an instance store volume,
which is typically created from a template stored in Amazon S3. When AWS
introduced Amazon EBS, the AMIs were backed by it, which means that the
root device for an instance was launched from the AMI, whereas the Amazon
EBS volume was created from an Amazon EBS snapshot.
The AWS Marketplace
The AWS Marketplace is similar to any online store where you can buy
products, and here you will buy software that runs on AWS, which includes
the AMIs that you can use to launch your EC2 instance. In the AWS
Marketplace, AMIs are organized into categories to allow you to find
products that suit your requirements. Amazon EC2 is integrated with the
AWS Marketplace to enable developers to charge other Amazon EC2 users
for their use of AMIs or to provide support for the Marketplace instances.
No additional parameters are required when launching an instance from a
paid AMI or launching it from any other AMI. The instance is charged the
standard usage fees of the related web services, like any other instances, in
addition to the rates set by the owner of the AMI, along with any additional
taxes.

AMIs Generated from Existing Instances


You can generate an AMI from an existing instance that has been made
available for other developers to use that has the components they need,
although they can add custom content. Share AMIs at your own risk—
Amazon won’t vouch for their integrity or security. When you receive a
shared AMI, you need to perform the appropriate due diligence and treat it as
you would any unknown code that you might consider deploying in your own
datacenter. AWS recommends getting shared AMIs from trusted sources. The
owner of the AMI is not charged when it is launched by other AWS accounts,
and only the accounts that are launching the shared AMI are billed for their
use. Since AMIs are a regional resource, it is available only in the same
region by default; if you want to make it available in a different region, you
need to copy the AMI to that region and then share it. However, AMIs with
encrypted volumes cannot be made public.

Tenancy Options
AWS provides a couple of options for tenancy, including the default type of
shared and dedicated models. For example, assume you have a single family
house—you could consider this a dedicated tenancy, since only one family
lives there. However, if you have an apartment building, several families
will be living in it, which would be a shared tenancy model.
Likewise, if multiple EC2 instances from different customers reside on
the same physical hardware, it’s called a shared tenancy model. If only your
EC2 instances run on hardware and no other customers can use that
hardware, it’s called a dedicated model.

Shared Tenancy
The default tenancy model is the most commonly used, where multiple
customers will share the same hardware even though they don’t interact with
each other. A hypervisor is running on the physical host to handle the
virtualization of CPU, memory, storage, etc. When you choose to deploy an
EC2 instance, AWS launches onto the appropriate physical host and isolates
it from other customers, even if it’s sharing the same physical resources.
Unless you have regulatory compliance or licensing restrictions to use the
dedicated model, you should be using shared tenancy, which is the cheaper
option.

Dedicated Tenancy
A dedicated tenancy ensures that your EC2 instances are run on hardware
dedicated to your account, but it is a costlier option. You might use it for
exclusive scenarios, like if you’re trying to use bring your own license
(BYOL), which is based on the socket model, where the number of hosts
sockets or cores are used for software licensing. In another scenario,
regulatory compliance may dictate that you can’t use the shared model. AWS
offers two different options for dedicated tenancy: dedicated hosts and
dedicated instances.

Dedicated Hosts
A dedicated host is a fully dedicated physical server that allows you to use
your existing licenses, including Windows and Linux Enterprise Server.
You’re allowed to spin up as many EC2 instances as that host will allow for
no additional charge, much like how you would manage an on-premises
solution. You cannot mix EC2 instance types on the same dedicated host.
You’ll pay for the whole host, so you are responsible for the utilization. If
you can manage that capacity well, this option may be cheaper than the
shared tenancy model.
Dedicated Instances
Dedicated instances are for a single customer that runs on dedicated
hardware, and even though it belongs to a different AWS account, it is
physically isolated at the hardware level. The dedicated instances physically
isolated at the hardware level are linked to a single-payer account. With a
dedicated instance, you are not paying for the entire host all at once but
you’re still receiving the benefits of having separate hosts from the rest of the
AWS customers. You are charged a higher rate for the instances, but you do
not need to worry about the capacity of the hosts. This type of instance model
ensures they’re kept separate, which is similar to the default model where
you don’t worry about where the instances are. You don’t want to manage the
hosts, but you need a dedicated instance for compliance reasons that require
that hosts are not shared between customers, and you can use the BYOL
options for anything licensed by the user.

Instance Types
The instance type determines the hardware of the host computer, for example,
different compute, storage, and memory, and it is grouped into families based
on these capabilities. When you launch an instance, you can select an
instance type based on your requirements in terms of application or software
need.
The CPU, memory, and instance storage are dedicated to a particular
instance and share the network and disk subsystem among other EC2
instances. Each instance on a host computer receives an equal share of those
shared resources, so it tries to use as much of these shared resources as
possible. However, an instance can consume a higher share of a resource
when another resource is underused. The instance types will have a larger
allocation of shared resources and provide higher or lower minimum
performance from a shared resource, like the instance types with high I/O
performance.

General Purpose
General-purpose instances can be used for a variety of workloads and
provide a balance between compute, memory, and networking resources.
A1 Instances
The EC2 A1 instances offer significant cost savings and are ideally suited for
scale-out workloads like web servers, containerized microservices, caching
fleets, distributed data stores, and Arm-based workloads that are supported
by the Arm ecosystem.

M5, M5a, M5ad, and M5d Instances


M5 instances offer a balance of compute, memory, and networking resources
for a broad range of applications like web and application servers, small and
medium databases, gaming servers, caching fleets, running SAP backend
servers, SharePoint, and cluster computing.

NOTE m5.metal and m5d.metal instances provide your applications with


direct access to the physical resources of the host server, such as processors
and memory. They are suitable for workloads that require access to low-
level hardware features that are not available or fully supported in
virtualized environments. They are also suitable for applications that require
a nonvirtualized environment for licensing or support.

T2, T3, and T3a Instances


These instances provide the ability to burst to a higher level of CPU
performance for any period of time when required by your workload. They
are suitable for web applications; code repositories; development, build,
test, and staging environments; and microservices.

Compute Optimized
Compute-optimized instances are ideal for compute-bound applications like
media transcoding, high-performance web servers, high-performance
computing (HPC), ad serving engines, scientific modeling, dedicated gaming
servers, machine learning inference, batch processing workloads, and other
compute-intensive applications that benefit from high-performance
processors.

Memory Optimized
Memory-optimized R instances are designed to deliver fast performance for
workloads that process large data sets in memory, like relational, NoSQL,
and in-memory databases. They are also well suited for applications that
perform real-time processing of big unstructured data.

NOTE r5.metal and r5d.metal instances provide direct access to the


physical resources of the host server, such as processors and memory. They
are well suited for workloads that require access to low-level hardware
features that are either not available or not fully supported in virtualized
environments and for any applications that require a nonvirtualized
environment for licensing or support.

High Memory Instances


High memory x1 and z1 instances offer 6TiB, 9TiB, or 12TiB of memory per
instance and are designed to run large in-memory databases, like production
installations of SAP HANA (an in-memory database), big data processing
engines such as Apache Spark or Presto, and HPC applications and
databases. These type of instances offer bare metal performance since it is
directly attached to the host hardware.

NOTE z1d.metal instances provide your applications with direct access to


the physical resources of the host server, such as processors and memory.
These instances are well suited for workloads that require access to low-
level hardware and applications that require a nonvirtualized environment
for licensing or support.

Storage Optimized
Storage-optimized instances are designed for workloads that require write
access to very large data sets on local storage, as well as high workloads
that perform sequential reads, like massive parallel processing (MPP) data
warehouses, large log or data processing applications, MapReduce, and
Hadoop distributed computing. They are optimized to deliver tens of
thousands of low-latency, random I/O operations per second (IOPS) to
applications like high-frequency online transaction processing (OLTP)
systems, relational databases, NoSQL databases, caching for in-memory
databases, data warehousing applications, and distributed file systems.

NOTE i3.metal instances provide your applications with direct access to


the physical resources of the host server, such as processors and memory.
The workloads that require access to low-level hardware features are well
suited for these instances because they are either not available or not fully
supported in virtualized environments. They are also ideal for applications
that require a nonvirtualized environment for licensing or support.

Accelerated Computing
Accelerated computing instances enable more parallelism for higher
throughput on compute-intensive workloads, and they provide access to
hardware-based compute accelerators such as graphics processing units
(GPUs) or field programmable gate arrays (FPGAs).
GPU-based instances provide access to NVIDIA GPUs with thousands of
compute cores, which can be used to accelerate scientific, engineering, and
rendering applications by leveraging the Compute Unified Device
Architecture (CUDA) or Open Computing Language (OpenCL) parallel
computing frameworks. This can be used for graphics applications like game
streaming and 3-D application streaming.
The elastic graphics accelerator is better suited for an instance type with
different compute, memory, or storage specifications and can also be used
when your application needs a small amount of additional graphics
acceleration. The hardware acceleration code can either be purchased
through the AWS Marketplace or you can develop it yourself.

NOTE FPGA-based instances do not support Microsoft Windows.

Pricing Model for EC2


AWS offers 750 hours of Linux and Windows t2.micro instances each month
for one year as part of the Free Tier option. As long as you use only EC2
micro instances, you will stay within the Free Tier amount. AWS offers four
cost models to pay for Amazon EC2 instances: on-demand, savings plans,
reserved instances, and spot instances. If you require EC2 instance capacity
on physical servers for your dedicated use, you will have pay for dedicated
hosts.
The EC2 instance lifecycle starts when it is newly launched and ends
whenever you terminate that instance. The purchasing option and pricing
affect the lifecycle as well. An on-demand instance runs from when you
launch and ends when you terminate it. A spot instance runs until the capacity
is available or until your maximum price is higher than the spot price. A
scheduled instance is launched during its scheduled start time and is
terminated three minutes before the scheduled time period ends.

EXAM TIP You need to know what kinds of purchasing options are best
suited for your requirements. Spot instances are well suited for workloads
that are short lived or that can accommodate interruption. Reserved
instances are best for consistent, long-term compute needs. On-demand
instances provide flexible compute power to respond to scaling needs.

AWS also offers per-second billing, which takes the cost of unused
instance minutes and seconds in an hour off of your bill, allowing you to
focus on improving your applications instead of planning to maximize the
usage to the hour. This especially benefits instances that run for irregular
periods of time, like development, testing, analytics, data processing, gaming
applications, and batch processing.
EC2 usage and provisioned storage for EBS volumes are billed in per-
second increments, with a minimum of 60 seconds. Per-second billing is
available for on-demand, reserved, and spot instances in all regions and
availability zones for Amazon Linux and Ubuntu.

On-Demand
On-demand instances are billed either per second or per hour for compute
capacity, depending on which instances you run. You don’t need any up-front
payments or any long-term commitments and only pay the specified hourly
rates for the instance you use.
AWS recommends on-demand instances for first-time application
development or proof of concepts (POCs) or for applications with short-
term, spiky, or unpredictable workloads. They have the advantage of low
cost and flexibility when launching EC2 without long-term commitments or
up-front payments.

Spot Instances
EC2 spot instances provide spare or unused Amazon EC2 computing
capacity for a price up to 90 percent less than the on-demand price. You can
lower your Amazon EC2 costs significantly, since spot instances are
available at steep discounts. Spot instance pricing is charged in hourly
increments. AWS sets and adjusts the spot price gradually based on the long-
term supply of and demand for spot instances in each availability zone. The
spot instance will be available to you when the maximum price per hour for
your request exceeds the spot price and the requested instance type capacity
is available.
If your applications can be interrupted at any time or your application is
flexible in terms of starting, then the spot instance is a cost-effective solution
with, as mentioned, nearly 90 percent savings. Spot instances are well suited
for applications that have flexible start and end times, optional tasks,
background processing, data analysis, and batch jobs.

EXAM TIP You need to know the properties of the Amazon EC2 pricing
options to help your customers save on cost. On-demand instances require
no up-front commitment, can be launched at any time, and are billed by the
hour. Reserved instances require an up-front commitment and vary in cost,
depending on whether they are paid entirely up-front, partially up-front, or
not at all up-front. When your bid price exceeds the current spot price, spot
instances are launched. Spot instances are terminated as soon as the spot
price exceeds your bid price, although you will be given a two-minute
warning before they terminate.

Reserved Instances
Reserved instances offer a significant discount—up to 72 percent in savings
—compared to the on-demand instance pricing. Reserved instances provide
a capacity reservation, since they are assigned to a specific availability zone,
which gives you the ability to launch instances whenever you need them. The
discount on reserved instances applies to on-demand instances or instances
running in your AWS account. Reserved instances are not physical instances.
In order to benefit from the billing discount, those on-demand instances must
meet certain attributes.
If your applications have a steady state of predictable usage over a long
period, reserved instances provide you with significant savings compared to
using on-demand instances. Customers are allowed to purchase reserved
instances over a one-year (31,536,000 seconds) or three-year (94,608,000
seconds) term to reduce total computing costs; the three-year plan offers a
deeper discount compared to the one-year commitment.
Dedicated Hosts
An Amazon EC2 dedicated host is a physical server fully dedicated to your
use with an EC2 instance capacity only allocated to you. Dedicated hosts
allow you to reduce costs by using your existing per-socket, per-core, or per-
VM software licenses, and can also help you meet compliance requirements.
It can be purchased on-demand on an hourly basis or as a reservation for up
to 70 percent off the on-demand price.

EXAM TIP You need to know how to combine multiple pricing options
that result in cost optimization and scalability. When you need to scale up a
web application that is running on reserved instances in response to a
temporary traffic spike, you can use on-demand instances. For a workload
with several reserved instances reading from a queue, it’s possible to use
spot instances to alleviate heavy traffic in a cost-effective way.

EC2 Instance Virtualization Types


Paravirtual (PV) and hardware virtual machine (HVM) are two types of
virtualization that Linux Amazon Machine Images use. The way the AMIs
boot and whether they use a special hardware extension for better
performance determine whether it is a PV or HVM AMI. AWS recommends
using the current-generation instance types and HVM AMIs when you launch
your instances for the best performance.

HVM AMIs
HVM AMIs boot your image by executing the master boot record of the root
block device and use a fully virtualized set of hardware. Without any
modification, you have the ability to run an operating system directly on top
of a virtual machine, as if it were run on the bare metal hardware. It emulates
some or all of the underlying hardware to the guest.
The host’s underlying hardware can be accessed quickly using HVM
guest hardware extensions. AMIs built using HVM provide enhanced
networking and GPU processing. The HVM virtualization provides native
hardware platform access to the OS through instructions to the network and
GPU devices.

PV AMIs
PV AMIs use PV-GRUB, a special boot loader, which starts the boot cycle
and then chain-loads the kernel specified in the menu.lst file on your image.
PV guests cannot take advantage of special hardware extensions, such as
enhanced networking or GPU processing, but they can run on host hardware
that does not have explicit support for virtualization. Current-generation
instance types do not support PV AMIs, whereas the previous generation
instance types, like C1, C3, HS1, M1, M3, M2, and T1, do support PV AMIs.
Using the AWS console or the describe-images command, you can find a PV
AMI and verify that the virtualization type is set to paravirtual.

Storage Options for Amazon EC2


You have the option to choose between AMIs backed by Amazon EBS and
AMIs backed by the Amazon EC2 instance store, based on your
requirements. However, AWS recommends using AMIs backed by Amazon
EBS instead of instance store–backed AMIs, because the EBS-backed AMI
launches faster and uses persistent storage.

Instance Store–Backed Instances


The root device has one or more instance store volumes available
automatically for the instances that use instance stores, with at least one
volume serving as the root device volume. The image that is used to boot the
instance is copied to the root volume when you create the instance. You can
also use additional instance store volumes, depending on the instance type.
NOTE You cannot stop the instance store–backed instances because this
action is not supported.

As long as the instance is running, the data on the instance store volumes
persists. The instance store data is deleted when the instance is terminated or
when the instance fails because of an underlying drive issue. These instances
cannot be restored in this scenario, so AWS recommends you distribute the
data on your instance stores across multiple availability zones. You need to
have solid backup strategy for your critical data of your instance store
volumes to persist the storage on a regular basis.

EXAM TIP You need to know the lifetime of an instance store. When the
instance is stopped or terminated, the data on an instance store is lost.
However, the instance store data will survive an OS reboot.

Amazon EBS–Backed Instances


Root devices have an Amazon EBS volume attached automatically for
instances that use Amazon EBS. AWS creates an EBS volume for each of the
EBS snapshots referenced by the AMI that you use when you launch an EBS-
backed instance. Depending on the instance type, you can either use other
Amazon EBS volumes or instance store volumes for your EBS-backed
instances.
The advantage of an Amazon EBS–backed instance is that it can be
stopped and (re)started without affecting data that is stored in the attached
volumes. When an Amazon EBS–backed instance is in a stopped state, you
can attach your root volume to a different running instance, update the kernel
it is using, modify the properties of the instance, or change its size.
You can attach the volume to the new instance by creating a snapshot of
the root volume and registering a new AMI. Based on your requirements,
launch a new instance from this new AMI. Then detach the remaining EBS
volumes from the old instance and reattach them to the new instance.
EXAM TIP You need to know how Amazon EBS–optimized instances
affect Amazon EBS performance. In addition to the IOPS that controls
performance in and out of the Amazon EBS volume, use Amazon EBS–
optimized instances to ensure additional dedicated capacity for Amazon
EBS I/O.

The EC2 Instance Lifecycle


The EC2 instance lifecycle starts from the moment you launch, and it goes
through various states until the instance terminates. This allows you to
provide the best possible experience to your customers with the applications
or sites that are hosted on the EC2. It is important to understand and know
how the instance lifecycle affects the EC2 instance billing, as shown in
Figure 4-2, both from the exam point of view and to support your enterprise
environment.

Figure 4-2 Instance lifecycle


When you launch an EC2 instance or when you restart an EC2 after being
in the stopped state, it first enters into the pending state. The pending state is
not billed for because the instance is preparing to enter the running state at
this time. Billing starts when the instance is in the running state and ready for
use. The instance is not billed for when it is preparing to be stopped;
however, billing does take place when the instance is preparing to hibernate.
The instance is not billed for when it is shut down and cannot be used.
During this state, the instance can be restarted at any time. It is not billed for
when the instance is preparing to be terminated (i.e., permanently deleted and
cannot be restarted).

Launching
As soon as you launch an instance, it goes to the pending state. AWS uses the
instance type to determine the hardware of the host computer and uses the
AMI to boot the instance. It enters into the running state once the instance is
ready. You can connect to your running instance the same way that you’d
connect to any computer to use it.
As soon as your instance transitions to the running state, even if the
instance remains idle and you don’t connect to it, you’re billed for each hour
or partial hour that you keep the instance running. An EC2 instance is a
virtual server, and you launch it using an AMI, which provides the
application server, operating system, and applications for your instance.
You can get started with Amazon EC2 for free when you sign up for AWS
using the Free Tier. You can use a micro instance for free for 12 months, and
Free Tier offers 750 hours per month of t2.micro or t3.micro instances,
depending on the region. If you launch an instance, you incur the standard
Amazon EC2 usage fees if it is not within the Free Tier.
You can connect to an instance after you launch it. However, there might
be a short time before you can connect to it. The instance receives a public
DNS name that you can use to contact the instance from the Internet. Other
instances within the same Virtual Private Cloud (VPC) can use the instance’s
private DNS name to contact it.

Bootstrapping
Bootstrapping can be used to install additional software or to customize the
configuration of the EC2 instances. You have the option of passing user
bootstrap data to the instance when you launch it that can be used to perform
common automated configuration tasks, and you can run scripts after the
instance starts. Shell scripts and cloud-init directives are two types of user
data that you can pass to Amazon EC2. When you use command-line tools to
launch instances, you can pass this data to the launch wizard as plain text or
as a file. When you use application programming interface (API) calls, you
can pass the bootstrap data as base64-encoded text. You can pass user data to
the instance when you launch a Windows instance in Amazon EC2, and it is
treated as opaque data that will be used by automated configuration tasks or
scripts that are run after the instance starts.

VM Import/Export
The VM Import/Export service helps you to easily import and export virtual
machine images from your on-premises environment to Amazon EC2 and
back. Instead of building the VMs from scratch to meet your IT security,
configuration management, and compliance requirements, you can leverage
your existing investments in the virtual machines and bring them into Amazon
EC2 as ready-to-use instances. You can deploy workloads across your IT
infrastructure by exporting the instances back to your on-premises
virtualization infrastructure. Except for the standard usage charges of
Amazon EC2 and Amazon S3, the VM Import/Export service is available at
no additional charge to you.
You can use the AWS command-line interface (CLI) or other developer
tools to import a virtual machine (VM) image from your on-premises
VMware environment. You can use the AWS Management Portal for vCenter
that converts your VM into an Amazon EC2 AMI as part of the import
process that you can use to run Amazon EC2 instances.
You can export previously imported EC2 instances by specifying the
target instance, virtual machine file format, and a destination S3 bucket, and
VM Import/Export will automatically export the instance to the S3 bucket.
You can then download from the S3 bucket and launch the exported VM into
your on-premises virtualization infrastructure. Windows and Linux VMs can
be imported that use Microsoft Hyper-V, Workstation, Citrix Xen, and
VMware ESX virtualization formats. Also you can export the previously
imported EC2 instances to Microsoft Hyper-V, Citrix Xen formats, or
VMware ESX.
EXAM TIP You need to know the capabilities of VM Import/Export. You
can import your existing virtual machines as AMIs or Amazon EC2 instances
to AWS using VM Import/Export. Amazon EC2 instances that were imported
through VM Import/Export can also be exported back to a virtual
environment.

Instance Recovery
You can create Amazon CloudWatch alarms that stop, terminate, reboot, or
recover an instance. You can monitor the EC2 instances and automatically
recover one when it becomes impaired due to any underlying hardware
failure or a problem that requires repair by AWS. However, terminated
instances cannot be recovered. The instance ID, private IP addresses, elastic
IP addresses, and all instance metadata of the recovered instance will be
identical to the original instance. The recovered instance runs in the
placement group if the impaired instance was launched in one.
The recovery action is initiated when the StatusCheckFailed_System
alarm is triggered, and you will be notified by the associated Amazon SNS
topic. The instance is migrated during an instance reboot, and any data that is
in memory is lost during instance recovery. The information is published to
the SNS topic when the process is complete, and you will receive an e-mail
notification that includes the status of the recovery attempt and any further
instructions. If you log in to the AWS Management console and navigate to
the EC2 main page, you will notice an instance reboot on the recovered
instance. In addition, when AWS schedules stop or retire an instance due to
the degradation of its underlying hardware, the recovery action can be
triggered. The public IPv4 address of your instance will be retained after
recovery. Common causes of system status check failures are loss of network
connectivity, hardware issues on the physical host that affect network
reachability, loss of system power, and software issues on the physical host.

Instance Metadata
Metadata is data about data, and EC2 instance metadata is data about the
EC2 instances that you will be using to configure and manage your running
instance. If you want to access user data that was specified when launching
your instance, use instance metadata. You can either specify configuration
parameters for your instance or attach it as a simple script. Instance metadata
can be used to build more generic AMIs, and you can modify the
configuration at launch time. For example, if you want to launch application
servers for various medium-size businesses, you can use the same AMI and
retrieve its content from your Amazon S3 bucket. If you want to add new
small business customers at any time, simply create a new S3 bucket, add
specific content to those new customers, and launch the new AMI. When an
EC2 instance is launched, its dynamic data, like instance-identity/document,
instance-identity/pkcs7, and instance-identity/signature, is generated.

NOTE You will not be billed for HTTP requests used to retrieve instance
metadata and user data.

You do not need to use the Amazon EC2 console or the AWS CLI to get
your instance metadata. The instance metadata is available from your running
instance, so you can write scripts to run from your instance like accessing the
local IP address of your instance to manage a connection to an external
application.
All categories of instance metadata can be retrieved from a running
instance using the following command:

The 169.254.169.254 IP address is a link-local address, and it is valid


only if you run it from the instance. You can use PowerShell cmdlets for
Windows to retrieve the details:
EXAM TIP You need to know what instance metadata is and how it’s
obtained. Metadata is information like instance ID, instance type, and
security groups about an Amazon EC2 instance, available from within the
instance. It can be obtained through an HTTP call to a specific IP address.

You can also install a third-party tool such as GNU Wget or cURL and
run the following from Linux machines:

CAUTION Instance metadata and user data are not protected by


cryptographic methods. So anyone who has access to the instance can
retrieve its metadata. Therefore, you should not store any sensitive data,
such as usernames and passwords, as user data and should take suitable
precautions to protect any sensitive data.

Instance Stop and Restart


If your instance root volume uses an Amazon EBS volume, it can be stopped
and restarted. The instance changes the public IPv4 address unless you have
assigned an elastic IP, and it retains its private IPv4 address and instance ID.
AWS shuts down the instance when you stop it, and you won’t be charged
for data transfer fees or usage charge for any stopped instances, but you incur
a charge for any attached Amazon EBS volumes. Every time you stop and
restart the instance, AWS charges a full instance hour, even if you stop and
start multiple times within a single hour.
You can treat its root volume like any other volume while the instance is
stopped and modify or repair any file system problems or update software.
Once you stop the instance, you can just detach the volume and attach it to a
running instance to make any required changes, detach the updated/repaired
EBS volume from the running instance, and then reattach it to the original
instance that was stopped. The storage device name should be the same as
the root device in the block device mapping for the instance.
When you stop a running instance, the instance performs a normal
shutdown and stops running. The status of the instance changes to “stopping.”
The data persists, and all the Amazon EBS volumes remain attached to the
instance. The instance store volumes of the host computer or any data stored
in the RAM of the host computer is deleted. The instance is migrated to a
new underlying host computer when you restart the stopped instance.
Whenever the instance is stopped and restarted, it retains its private IPv4
addresses and any IPv6 addresses. AWS assigns a new public IPv4 address
when you restart the instance and releases the existing public IPv4 address
but retains its associated elastic IP addresses. In this case, you will be
charged for any elastic IP addresses associated with your stopped instance.
When you stop and start a Windows instance, the EC2Config service
changes the drive letters for any attached Amazon EBS volume. Amazon EC2
returns the IncorrectInstanceState error when you try to modify instance type,
user data, kernel, and RAM disk attributes while the instance is running, and
you can modify them only when it is stopped.

Instance Hibernate
Instance Hibernate signals the operating system to perform hibernation,
which saves the contents from the instance memory (RAM) to the Amazon
EBS root volume. AWS preserves your instance’s Amazon EBS root volume
along with all other attached Amazon EBS data volumes during hibernation.
When you restart your hibernated instance, the instance ID is retained, the
EBS root volume is restored, the RAM contents are reloaded, and the
processes are resumed in addition to reattaching the data volumes.
AWS won’t charge when it is in the stopped state; however, it will
charge for usage while the instance is in the stopped state during that time
and the contents of the RAM are transferred to your EBS root volume. AWS
won’t charge usage for data transfer, but it will charge for the EBS volume
storage.

Instance Reboot
It takes only a few minutes to reboot your instance, and it remains on the
same physical host by keeping the same public DNS name (IPv4), IPv6
address, private IPv4 address, and any data on its instance store volumes.
Rebooting is does not incur a charge and doesn’t start a new instance billing
period. You can schedule your instance for a reboot for necessary
maintenance or any updates. You should use the Amazon EC2 console or a
command-line tool or the Amazon EC2 API used to reboot your instance
instead of using the operating system reboot command. AWS performs a hard
reboot when you use the Amazon EC2 console, a command-line tool, or the
Amazon EC2 API to reboot your instance but it does not cleanly shut down
within four minutes.

Instance Retirement
AWS schedules an instance retirement when it detects an irreparable failure
of the underlying hardware host. If your instance root device is an Amazon
EBS volume, it is stopped; if your instance root device is an instance store
volume, it is terminated by AWS as soon as it reaches its scheduled
retirement date. Stopped instances migrate to a new hardware host, and the
terminated instance cannot be used again.

Instance Termination
Terminating an instance refers to deleting your instance when you no longer
need it. You stop incurring charges as soon as the state of an instance changes
to shutting down or terminated. Once you have terminated the instance, you
can’t connect to it or restart it. However, it remains visible in the console for
a short while, until resources such as tags and volumes are gradually
disassociated from the instance, and then the entry is automatically deleted.
When an instance gets terminated, the data on any associated instance store
volumes, Amazon EBS root device volumes, and any additional EBS
volumes is deleted unless you have set the DeleteOnTermination attribute to
false for EBS volumes.
Generating Security Keys
Public key cryptography is used by Amazon EC2 to encrypt and then decrypt
login information for EC2 instances. A public key will be used to encrypt a
piece of data, and then a private key will be used by the recipient to decrypt
the data. This pair of public and private keys is called a key pair.
You specify the key pair when you launch an instance. You can either
specify a new key pair or an existing key pair that you create at the launch of
an instance. The public key content is placed on the instance in an entry
within ~/.ssh/authorized_keys at boot time. You must specify the private key
to log in to your instance.
Amazon EC2 will be used to create the key pair, or you can use third-
party solutions. You store the private key, and Amazon EC2 stores the public
key with the name that you specify as the key name. It is your responsibility
to store your private keys in a secure place because anyone who possesses
your private key can decrypt your login information. The 2048-bit SSH-2
RSA keys are used by Amazon EC2, and you are allowed to have up to 5,000
key pairs per region.
You won’t be able to connect to the instance if you don’t specify a key
pair when you launch it. You must specify the private key when you connect
to the instance that corresponds to the key pair you specified when you
launched it.

NOTE AWS doesn’t store a copy of your private key, so if the private key
that you own is lost, there is no way to recover it.

You can add user accounts to your instance when several users require
access. You need to add the public key information of each user key pair to
the .ssh/authorized_keys file on your instance. You can distribute
corresponding private key files to each user instead of distributing the root
account private key file to multiple users.
Launching an Amazon EC2
You can launch a micro instance for free for 12 months when you use the Free
Tier. You will be charged the standard Amazon EC2 usage fees if you launch
an instance that is not within the Free Tier.
After you launch your instance, the state changes to pending. The instance
will start booting before the state changes it to running. You can connect to
the instance from the Internet using the public DNS name. You can also
connect to the instance using its private DNS name.

Creating an Amazon EC2 Instance


The following are the steps to create your first Amazon EC2 instance:
1. Go to https://console.aws.amazon.com/ec2/ to open the Amazon EC2
console.
2. Select the region for the instance from the navigation bar at the top of
the screen.
3. Choose Launch Instance from the Amazon EC2 console dashboard.
4. Choose an AMI on the Choose an Amazon Machine Image page:
• Quick Start (this is the most popular option and lets you get started
quickly)
• My AMIs (private AMIs that either you own or are shared)
• AWS Marketplace (an online store to buy AMIs that run on AWS)
• Community AMIs (AWS community members share AMIs for others to
use)
5. On the Choose An Instance Type page, choose the t2.micro instance type
to remain in the Free Tier.
6. Then choose Next: Add Storage.
7. In the Network option, select the VPC where you want to create this
instance.
8. In the Subnet option, select the subnet where you want to launch your
instance.
9. Select Auto-Assign Public IP to receive a public IPv4 address, or select
Auto-Assign IPv6 IP if your instance needs an IPv6 address.
10. Provide the AWS Identity and Access Management (IAM) role if you
want to associate this with the Amazon EC2 instance that you are
creating in this exercise.
11. Then choose the option to either stop or terminate the instance when it is
shut down.
12. Select the check box to enable termination protection and prevent
accidental termination.
13. Select the check box to enable detailed Amazon CloudWatch
monitoring.
14. Choose Tenancy, Dedicated Hardware, or on a Dedicated Host, based
on your requirements, for an additional cost.
15. Select the T2/T3 Unlimited check box to burst beyond the baseline for
an additional charge.
16. Select an existing placement group if you want this instance to be placed
in one.
17. Specify user data to run a configuration script or to configure an
instance during launch, or to attach a configuration file.
18. On the Add Storage page, specify additional volumes to attach to the
instance if required.
• Type Select the instance store or Amazon EBS volumes based on
your requirement.
• Device Select the device name from the list for the volume.
• Snapshot To restore a volume, enter the name or ID of the snapshot.
• Size You can specify a storage size, but for the Free Tier, you must
remain under 30GiB of total storage.
• Volume Type For EBS volumes, select Magnetic Volume or
Provisioned IOPS SSD or General Purpose SSD.
• IOPS Enter the number of IOPS for the Provisioned IOPS SSD
volume type.
• Delete On Termination To delete the volume when the instance is
terminated, select this check box.
• Encrypted Select this option to encrypt the volume.
19. On the Add Tags page, specify tags for key and value pairs for the
instance and volumes.
20. Choose Next to navigate to the Configure Security Group page.
21. Select an existing security group, or create new one to define the
firewall rules for your instance.
22. Choose Review And Launch.
23. Check the details of your instance, and make changes if necessary.
24. Choose Launch when you are ready.
25. Now you will be prompted to select an existing key pair or create a new
key pair.
26. The instance will be in a pending state until the boot configuration is
complete.
27. You can connect to the instance as soon as its state changes to running.

Connecting to the Amazon EC2 Instance Using SSH


This exercise will help you connect to your Amazon EC2 instance using the
SSH client.
1. You can connect to your instance and use it the way that you’d connect
to any computer.
2. Verify that your instance passes the status checks.
3. Install an SSH client (openssh.com) on your local computer if it’s not
already installed (by typing ssh at the command line) by default.
4. Type ssh -i /mypath/my-ins-key-pair.pemec2-user@ec2-197-38-200-
6.compute-1.amazonaws.com (this gets your EC2 instance host name
from the EC2 console). The text breaks down as follows:
• ssh command connects to the instance.
• my-ins-key-pair.pem is your private key file along with its path.
• ec2-user is the user name for your AMI.
• ec2-197-38-200-6.compute-1.amazonaws.com is the public DNS
name for your instance.
5. You will be asked if you want to continue connecting.
6. When you type yes, you will see a response similar to “Warning:
Permanently added ‘ec2-198-51-100-1.compute-1.amazonaws.com’
(RSA) to the list of known hosts.” Now you are connected to your
instance.

Connecting to an Amazon EC2 Instance Using a PuTTY


Session
This exercise will show step-by-step details to connect to your Amazon EC2
instance using a PuTTy tool.
1. A few minutes after the instance is launched, the status checks will be
passed and you are ready to connect.
2. Download and install PuTTY on your local computer.
3. Convert your private key format (.pem) to the PuTTYgeninto (.ppk)
format.
4. Start PuTTY from your Start menu.
5. Choose Session in the Category pane.
6. Enter user_name@public_dns_name in the Host Name box (the
username is ec2-user for Amazon Linux AMI and ubuntu for Ubuntu
AMI).
7. Select SSH under Connection Type.
8. The Port Value is 22.
9. In the Category pane, expand Connection, SSH, and then Auth.
10. Choose Browse, select the .ppk file, and choose Open.
11. You can save the session under Category then Session, enter a name, and
choose Save.
12. Choose Open.
13. PuTTY displays a security warning asking whether you trust the host.
14. Verify the fingerprint in the Security Alert dialog box to avoid a “man-
in-the-middle” attack (this is an optional security feature).
15. If the fingerprint matches, choose Yes. Now you are connected to your
instance.

EXAM TIP You need to know the methods for accessing an instance over
the Internet. You can access an Amazon EC2 instance over the Web via a
public IP address, elastic IP address, or public DNS name. The private IP
addresses and Elastic Network Interface (ENI) are additional ways to
access an instance within an Amazon VPC.

Security Groups that Protect the Instances


A security group acts like a virtual firewall by controlling traffic to or from
its associated instances, and you can add rules to allow traffic. When you
launch an instance, you need to specify one or more security groups;
otherwise, AWS uses the default security group. When you modify the
security group, the new rules are automatically applied to all of its
associated instances. AWS evaluates all the rules from all the security groups
that are associated with the instance before deciding whether to allow traffic
or not. You can maintain your own firewall on any of your instances in
addition to using security groups when you have requirements that aren’t met
by security groups.
Security groups allow all outbound traffic by default, and the rules are
always permissive, which means you can’t create rules that deny access.
Security groups are stateful, so the return response traffic for that request is
allowed to flow in, regardless of inbound security group rules. Security
Group rules can be added and removed at any time. Any changes you make to
the security groups are automatically applied immediately to the associated
instances.
The rules from each security group are effectively aggregated when you
associate multiple security groups with an instance to create one set of rules.
AWS uses this set of rules to determine whether to allow access to the
instance. An instance can have hundreds of rules, since you can assign
multiple security groups to an instance, but that might cause problems when
accessing the instance. Thus AWS recommends that you condense your rules
as much as possible.

EXAM TIP You need to know how security groups protect instances.
Amazon EC2 instances use security groups as virtual firewalls, controlling
traffic in and out of your instance. The inbound access of your custom
security group is set to deny by default, and you can allow traffic by adding
rules specifying traffic direction, port, protocol, and destination address via
a Classless Inter-Domain Routing (CIDR) block. They are applied at the
instance level, meaning that traffic between instances in the same security
group must adhere to the rules of that security group. They are stateful, so if
you send an outbound request from your instance, the return response
inbound traffic is allowed, regardless of inbound security group rules, and
vice versa.

The rule affects all instances associated with the security group when you
specify a security group as the source or destination for a rule. Incoming
traffic is allowed based on the private IP addresses, not the public IP or
elastic IP addresses, of the instances that are associated with the source
security group. AWS applies the most permissive rule if more than one rule
is specified for a specific port.
The security group tracks information about traffic to and from the
instance. Rules are applied to determine if the traffic is allowed or denied
based on its connection state. The responses to inbound traffic are allowed to
flow out, regardless of outbound security group rules and vice versa because
security groups are stateful. The response traffic is not tracked.
EXAM TIP You need to know how to interpret the effect of security
groups. When an instance is a member of multiple security groups, the effect
is a union of all the rules in all the groups. Understand how AWS applies the
most permissive rule if more than one rule is specified for a given port.

Best Practices for Amazon EC2


Follow these best practices to get the maximum benefit from Amazon EC2:
• It is very important to manage access to Amazon EC2 using identity
federation, Identity and Access Management (IAM) users, and IAM
roles.
• Credential management policies and procedures needs to be established
for creating, distributing, rotating, and revoking AWS access credentials.
• The recommended approach is to implement the least permissive rules
for your security group.
• You need to regularly patch, update, and secure the operating system and
applications on your instance.
• Make sure you understand the implications of your instance root device
type for data persistence, backup, and recovery.
• You need to use separate Amazon EBS volumes for the operating system
versus your data.
• If required, you need to ensure that the volume with your data persists
after instance termination and keep in mind that it’s going to incur
charges.
• Use the instance store for your instance to store temporary data.
• Always keep in mind that the data stored in an instance store is deleted
when you stop or terminate your instance, so make sure you have a
cluster with a replication factor that ensures fault tolerance when you
use the instance store for database storage.
• You need to use instance metadata and custom resource tags to track and
identify your AWS resources.
• Be aware of your current limits for Amazon EC2 and request any
increases in advance if required.
• You need to regularly back up your EBS volumes using Amazon EBS
snapshots and create an AMI to save the configuration of your instance
as a template for launching future instances.
• AWS recommends deploying critical components of your application
across multiple availability zones and replicating your data
appropriately.
• If you are not using elastic IP addresses, then design your applications to
handle dynamic IP addressing when your instance restarts.
• Use AWS CloudWatch Monitor to set up alerts and respond to events.
• To handle failover, you can either manually attach a network interface or
elastic IP address to your replacement instance or use Amazon EC2
Auto Scaling.
• It is recommended that you regularly test the process of recovering your
instances and Amazon EBS volumes if they fail as part of your business
continuation plan.

Chapter Review
This chapter began by explaining all the necessary details that you need to
know before creating your first EC2 instance. You learned what Amazon
Elastic Compute Cloud (EC2) is. You explored the package with the bits that
you need for your server, including the operating system and additional
software, as preconfigured templates for your instances, also known as
AMIs. PV and HVM are two types of virtualization that Linux AMIs use. The
instance type relates to various configurations of CPU, memory, storage, and
networking capacity. General-purpose instances can be used for a variety of
workloads and provide a balance of compute, memory, and networking
resources. Compute-optimized instances are ideal for compute-bound
applications and other compute-intensive applications that benefit from high-
performance processors. If you have workloads that process large data sets
in memory, you need memory-optimized instances that are designed to
deliver fast performance. If you have workloads that require high, sequential
read and write access to very large data sets on local storage, you need
storage-optimized instances. Accelerated computing instances enable more
parallelism for higher throughput on compute-intensive workloads and
provide access to hardware-based compute accelerators.
The chapter then explained how to secure login information for your
instances using key pairs, where AWS stores the public key in the instance
and you store your private key in a secure place. Amazon EC2 provides a
web-based user interface called the Amazon EC2 console. You can access
the Amazon EC2 console from the AWS Management Console and select the
EC2 console page. You can launch Amazon EC2 resources, such as instances
and volumes, directly from this console. The AWS CLI is supported on
Windows, Mac, and Linux and provides commands for a broad set of AWS
products. AWS also supports Windows PowerShell, which provides
commands for a broad set of AWS products. Amazon EC2 provides a query
API, and all these requests are HTTP or HTTPS requests that use the GET or
POST and an Action parameter. AWS provides resources for software
developers to build applications using language-specific APIs instead of
submitting a request over HTTP or HTTPS. These libraries make it easier
for you to get started by providing basic functions that automate tasks such as
cryptographically signing your requests, handling error responses, and
retrying requests.
Instance store volumes are used for temporary data that is deleted when
you stop or terminate your instance. Amazon EBS volumes are persistent
storage volumes for your instance data and root volume. Your instances and
EBS volumes can be spread across multiple physical locations known as
regions and availability zones. Security groups act as another firewall that
enables you to specify inbound and outbound rules for the protocols, ports,
and source IP ranges that can reach your instances. Elastic IP addresses are
static IPv4 addresses that can be assigned to your EC2 instances and network
interfaces. Tags are stored as key values on your Amazon EC2 resources.
Metadata is data about data, and EC2 instance metadata is data about the
EC2 instances that you will be using to configure and manage your running
instance.
VM Import/Export is used to import VM images from your local on-
premises environment into AWS and convert them into ready-to-use AMIs or
instances. You can get started with Amazon EC2 for free using the Free Tier,
and Amazon EC2 provides various purchasing options for additional
instances. You can pay for the instances that you use and are charged per
second, with no up-front payments or long-term commitments, by using on-
demand instances. You can make a one-time, low, up-front payment for an
instance and reserve it for a one- or three-year term, which allows you to pay
a significantly lower hourly rate for your instances by using reserved
instances. You can request unused EC2 instances, which can lower your costs
significantly up to 90 percent by using spot instances.

Exercises
The following exercises will help you practice performing various tasks in
Amazon EC2. You need to create an AWS account before you can perform
these exercises. You can use the Free Tier when launching AWS resources,
but make sure to terminate them at the end.

Exercise 4-1: Choosing an AMI by Root Device Type


The AMI that you specify when you launch your instance determines the type
of root device volume that your instance has.
1. Open the Amazon EC2 console.
2. In the Navigation pane, choose AMIs.
3. From the filter lists, select the image type, and from the search bar
choose Platform to select the operating system, like Amazon Linux, and
Root Device Type to select EBS images.
4. Choose the Show/Hide Columns icon to see additional information,
update the columns to display, and then choose Close.
5. Choose an AMI and write down its AMI ID.

Exercise 4-2: Selecting an Instance Store–Backed AMI


This exercise will show you the steps to select an instance store–backed
AMI.
1. Open the Amazon EC2 console.
2. In the Navigation pane, choose AMIs.
3. From the filter lists, select the image type from the search bar, choose
Platform to select the operating system, like Amazon Linux, and Root
Device Type to select the Instance store.
4. Choose the Show/Hide Columns icon to get additional information to
help you make your choice, update the columns to display, and then
choose Close.
5. Choose an AMI and write down its AMI ID.

Exercise 4-3: Checking the Root Device Type of an Instance


This exercise will show you the steps to check whether the root device type
of an instance is an instance store or EBS volume.
1. Open the Amazon EC2 console.
2. Choose Instances from the Navigation pane and select the instance you
want.
3. You can then check the value of the Root device type in the Description
tab.
4. This is an Amazon EBS–backed instance if the value is EBS. This is an
instance store–backed instance if the value is instance store.

Exercise 4-4: Modifying the Root Device Volume to Persist at


Launch
This exercise will show you the steps to modify the configuration of the root
device volume at launch in order to persist this volume even after termination
of its attached instance.
1. Open the Amazon EC2 console.
2. Choose Launch Instance from the Amazon EC2 console dashboard.
3. Select the AMI to use from the Choose an AMI page, and choose Select.
4. Choose an Instance Type and Configure Instance Details pages in the
wizard.
5. Deselect Delete On Termination for the root volume on the Add Storage
page.
6. After completing the remaining wizard pages, choose Launch.
7. You can verify the setting on the instance’s Details pane by viewing
details for the root device volume. Choose the entry for the root device
volume next to Block Devices. Delete On Termination is True by
default. Delete On Termination becomes False when you change the
default behavior.

Questions
The following questions will help you gauge your understanding of Amazon
EC2. Read all the answers carefully because there might be more than one
correct answer. Choose the best responses for each question.
1. You have launched an EBS–backed EC2 instance in the us-west-2a
region. To save on costs, you have stopped the instance and then tried to
start it back after 35 days, but you are getting the “Insufficient Instance
Capacity” error. What could be the reason for this error?
A. AWS does not have sufficient on-demand capacity in that availability
zone to service your request
B. AWS availability zone mapping is changed for your user account
C. There is an issue with the host machine capacity on which the
instance is launched
D. Your AWS account has reached the maximum EC2 instance limit
2. You are trying to connect to a running EC2 instance using SSH and are
getting an “Unprotected Private Key File” error. Which of the following
options can be a possible reason?
A. Your private key file has the wrong file permission
B. The .ppk file used for SSH has read-only permission
C. The public key file has insufficient permission
D. The username that you have provided is incorrect
3. You have launched an EC2 instance, but it was terminated. Is it possible
to find the reason for termination and, if so, where can you find the
details?
A. It is not possible to find the details after the instance is terminated
B. You can get the information by checking the instance description
under the State Transition Reason label from the AWS console
C. You can get the information by checking the instance description
under the Status Change Reason label from the AWS console
D. You can get the information by checking the instance description
under the Instance Change Reason label from the AWS console
4. A user is trying to connect to a running EC2 instance using SSH, but the
user gets a connection timeout error. Which is not a possible reason for
rejection?
A. You are connecting with the appropriate username for your instance
AMI
B. The security group is not configured properly to allow SSH
C. The private key used to connect to the instance is not correct
D. Your network ACL rules do not allow any inbound and outbound
traffic
5. You are launching an EC2 instance in the US West region. Which option
is recommended by AWS when selecting the availability zone?
A. Always select us-west-1aavailability zone for high availability
B. Do not select the availability zone; instead, let AWS choose it
C. You cannot select the availability zone when launching an instance
D. Always choose multiple availability zones when launching an
instance
6. What are the two types of virtualization that Linux AMIs take advantage
of in terms of special hardware extensions to boot the instance for better
performance? (Choose two.)
A. Amazon EC2 placement groups
B. Amazon PV AMI
C. Amazon HVM AMI
D. Amazon VPC
7. Which of the following statements about Amazon instance store is
correct?
A. Instance store volume data persists only for the duration of the life of
the Amazon EC2 instance
B. When you update the security group rule, the data on the associated
instance store volume will be lost
C. Even after the associated Amazon EC2 instance is terminated, the
data on an instance store volume persists until you manually delete it
D. The instance store volume is recommended for the root volume of
critical instances
8. You have launched an EC2 instance from an instance store–backed AMI
and attached an additional instance store volume to it. Now you want to
create an AMI from the running instance. Where will the additional
instance store volume data be located?
A. The additional instance store volume information will be on the
block device mapping
B. Only the root volume bundled on the instance uses instance store–
backed AMIs
C. It is not possible to add an instance store volume to the existing
instance store
D. It will not be a part of the AMI, since this is ephemeral storage
9. A user is using an EBS-backed instance. Which statement is true?
A. Only when the instance is running will the user be charged for the
volume and instance
B. The user will be charged for the volume even if the instance is
stopped
C. Only the cost of the running instance will be charged to the user
D. The user will not be charged for the volume if the instance is stopped
10. Status monitoring helps to quickly determine any problems that might
prevent instances from running applications. EC2 automatically
performs checks on every running EC2 instance to identify any
hardware or software issues. Which of the following is true? (Choose
two.)
A. Status checks are performed every minute, and each returns a pass or
a fail status
B. If all checks pass, the overall status of the instance is OK
C. If one or more checks fail, the overall status is Impaired
D. Status checks cannot be disabled or deleted, since they are built into
EC2

Answers
1. A. If you get an “Insufficient Instance Capacity” error when you try to
launch an instance or restart a stopped instance, AWS does not currently
have enough available on-demand capacity to service your request.
2. A. You need to set the 700 permission for the .ssh folder and set the 600
permission for the private key file. You need to grant the 644 permission
to your public key file.
3. B. You can get the information by checking the instance description
under the State Transition Reason label from the AWS console.
4. A. You are connecting with the appropriate username for your instance
AMI. For the Amazon Linux AMI, the username is ec2-user; for an
Ubuntu AMI, the username is ubuntu.
5. B. Do not select the availability zone; instead, let AWS choose it.
6. B, C. Amazon PV AMI and Amazon HVM AMI.
7. A. The data of instance store volume on your Amazon EC2 instance
persists only during the life of the instance.
8. A. Yes, the additional instance store volume information will be on the
block device mapping.
9. B. As long as there are attached EBS volumes to the EC2 instance, the
user will be charged even if the instance is stopped.
10. B, C. If all checks pass, the overall status of the instance is OK. If one
or more checks fail, the overall status is Impaired.

Additional Resources
• AWS References There is no place like official AWS documentation
to get the most up-to-date information about all the AWS services.
Always refer to the official AWS blogs to get the latest updates about
new AWS services and updates to existing features.

• Amazon EC2 Instance Connect This blog provides detailed steps to


configure instance connections using a custom AuthorizedKeysCommand
script.

• Hyper-V on Amazon EC2 This blog provides steps for launching,


setting up, and configuring a Hyper-V–enabled host, launching a guest
VM within Hyper-V running on i3.metal.

• Amazon EC2 Spot Instances This blog explains how to use the spot
instance interruption notices in CloudWatch events to automatically
deregister spot instances.

• Twelve-Factor App This blog explains how to apply and compare the
Twelve-Factor methodology to serverless application development for
building modern, cloud-native applications.

• Lift-and-Shift EC2 Migration This blog details the steps of automated


migration using the CloudEndure tool to migrate a virtual machine from
an on-premises environment to EC2 in AWS.

• EC2 Predictive Scaling This blog explains the steps to enable machine
learning models to predict the EC2 usage and scale EC2 based on the
prediction.

You might also like