Building Static Websites On AWS
Building Static Websites On AWS
on AWS
Prescriptive Guidance
May 2017
© 2017, Amazon Web Services, Inc. or its affiliates. All rights reserved.
Notices
This document is provided for informational purposes only. It represents AWS’s
current product offerings and practices as of the date of issue of this document,
which are subject to change without notice. Customers are responsible for
making their own independent assessment of the information in this document
and any use of AWS’s products or services, each of which is provided “as is”
without warranty of any kind, whether express or implied. This document does
not create any warranties, representations, contractual commitments,
conditions or assurances from AWS, its affiliates, suppliers or licensors. The
responsibilities and liabilities of AWS to its customers are controlled by AWS
agreements, and this document is not part of, nor does it modify, any agreement
between AWS and its customers.
Contents
Introduction 1
Static Versus Dynamic Website 1
Core Architecture 2
Moving to an AWS Architecture 4
Use Amazon S3 Website Hosting to Host Without a Single Web Server 5
Scalability and Availability 6
Configuration Basics 7
Evolving the Architecture with Amazon CloudFront 12
Factors Contributing to Page Load Latency 12
Speeding Up Your Amazon S3-Based Website Using Amazon CloudFront 13
Amazon CloudFront Reports 16
Estimating and Tracking AWS Spend 19
Estimating AWS Spend 20
Tracking AWS Spend 21
Integration with Your Continuous Deployment Process 22
Access Logs 23
Analyzing Logs 23
Archiving and Purging Logs 24
Securing Administrative Access to Your Website Resources 25
Managing Administrator Privileges 26
Auditing API Calls Made in Your AWS Account 28
Controlling How Long Amazon S3 Content Is Cached by Amazon CloudFront 28
Conclusion 33
Contributors 33
Abstract
This whitepaper covers comprehensive architectural guidance for developing,
deploying, and managing static websites on Amazon Web Services (AWS) while
keeping operational simplicity and business requirements in mind. We also
recommend an approach that provides these business benefits: 1) insignificant
cost of operation, 2) little or no management required, and 3) a highly scalable,
resilient, and reliable website.
This whitepaper first reviews how static websites are hosted in traditional
hosting environments. Then we explore a simpler and more cost-efficient
approach using Amazon Simple Storage Service (Amazon S3). Finally, we show
you how you can enhance the AWS architecture to layer on functionality and
improve quality of service by using Amazon CloudFront.
Amazon Web Services – Hosting Static Websites on AWS
Introduction
As enterprises become more digital operations, we see a proliferation of many
kinds of websites. They span a wide spectrum, from mission-critical e-commerce
sites to departmental apps, and from business-to-business (B2B) portals to
marketing sites. Many factors such as business value, mission criticality, service
level agreements (SLAs), quality of service, and information security will drive
the choice of architecture and technology stack.
The simplest form of website architecture is the static website, where users are
served static content (HTML, images, video, JavaScript, style sheets, etc.). Some
examples include brand micro sites, marketing websites, and intranet
information pages. Static websites are straightforward in one sense, but they
still can have demanding requirements in terms of scalability, availability, and
service-level guarantees. For example, a marketing site for a consumer brand
might need to be prepared for an unpredictable onslaught of visitors when a
new product is launched.
• Marketing websites
Page 1 of 44
Amazon Web Services – Hosting Static Websites on AWS
• Team homepages
• A website that lists available assets (e.g., image files, video files, and
press releases) allows the user to download the files as-is
• Proofs-of-concept used in the early stages of web development to test
user experience flows and gather feedback
Static websites load faster than dynamic ones, since content is delivered as-is
and can be cached by a content delivery network (CDN), and the web server
doesn’t need to perform any application logic or database queries. They’re also
relatively inexpensive to develop and host. However, maintaining large static
websites can be cumbersome without the aid of automated tools, and static
websites can’t deliver personalized information.
Static websites are most suitable when the content is infrequently updated. After
the content evolves in complexity or needs to be frequently updated,
personalized, or dynamically generated, it's time to consider a dynamic website
architecture.
Core Architecture
In a traditional (non-AWS) architecture, web servers serve up static content.
Typically, content is managed using a content management system (CMS), and
multiple static sites will be hosted on the same infrastructure. The content is
stored on local disks, or on a file share on network-accessible storage. A sample
file system structure might look like the structure that follows.
Page 2 of 44
Amazon Web Services – Hosting Static Websites on AWS
├─ css/
│ ├─ main.css
│ └─ navigation.css
├─ images/
│ ├─ banner.jpg
│ └─ logo.jpg
├─ index.html
├─ scripts/
│ ├─ script1.js
│ └─ script2.js
├─ section1.html
└─ section2.html
Page 3 of 44
Amazon Web Services – Hosting Static Websites on AWS
You can run Linux or Windows web servers on Amazon Elastic Compute Cloud
(Amazon EC2). You can use Elastic Load Balancing (ELB) to load balance and
distribute the web traffic. The static content can be stored on Amazon Elastic
Block Store (Amazon EBS) or Amazon Elastic File System (Amazon EFS). You
can deploy your Amazon EC2 instances in an Amazon Virtual Private Cloud
(Amazon VPC), which is your isolated and private virtual network in the AWS
Cloud. This gives you full control over the network topology, firewall
configuration, and routing rules. The web servers can be spread across multiple
Availability Zones for high availability, even if an entire data center were to be
down. You can use Auto Scaling to automatically add servers during high traffic
periods and then scale back when traffic quiets down.
Page 4 of 44
Amazon Web Services – Hosting Static Websites on AWS
Using this AWS architecture you gain the security, scalability, cost, and agility
benefits of running in AWS. This architecture benefits from AWS world-class
infrastructure and security operations. By using Auto Scaling, the website is
ready for traffic spikes, so you are prepared for product launches and viral
websites. With AWS, you only pay for what you use, and there’s no need to over-
provision for peak capacity. In addition, you gain from increased agility because
AWS services are available on demand. (Compare this to the traditional process
in which provisioning servers, storage, or networking can take weeks.) You don’t
have to manage infrastructure, so this frees up time and resources to create
business-differentiating value. In many ways, this initial AWS architecture is a
major win over the non-AWS one.
You can start by creating an Amazon S3 bucket, enabling the Amazon S3 website
hosting feature, and configuring access permissions for the bucket. After you
upload files, Amazon S3 takes care of serving your content to your visitors.
Page 5 of 44
Amazon Web Services – Hosting Static Websites on AWS
Page 6 of 44
Amazon Web Services – Hosting Static Websites on AWS
uses to run its own global network of websites. As soon as you upload files to
Amazon S3, Amazon S3 automatically replicates your content across multiple
data centers. Even if an entire AWS data center were to be impaired, your static
website would still be running and available to your end users.
Configuration Basics
Getting started is easy. First, open the AWS Management Console, where you
will create an Amazon S3 bucket using the Amazon S3 console. When you first
create an S3 bucket, you select the AWS Region in which the files will be
geographically stored. 4 Select a Region based on its proximity to your visitors,
proximity to your corporate data centers, and/or your regulatory or compliance
requirements (e.g., some countries have restrictive data residency regulations).
Since Amazon S3 supports virtual-host style access to your Amazon S3 buckets,
the bucket name must comply with DNS naming conventions. 5 If you plan to use
your own custom domain/subdomain, such as example.com or
www.example.com, your bucket name must be the same as your
domain/subdomain. For example, a website available at
http://www.example.com needs to be in a bucket named www.example.com.
Each AWS account can have a maximum of 1000 buckets.
After your Amazon S3 bucket is created, toggle on the static website hosting
feature for the bucket. 6 This will generate an Amazon S3 website endpoint. You
will be able to access your Amazon S3-hosted website at the following URL:
http://<bucket-name>.s3-website-<AWS-region>.amazonaws.com
Page 7 of 44
Amazon Web Services – Hosting Static Websites on AWS
domain name, your bucket name must match the domain name. For custom
root domains (such as example.com), only Amazon Route 53 can configure a
DNS record to point to the Amazon S3-hosted website. For non-root
subdomains (such as www.example.com), any DNS service (including Amazon
Route 53) will be able to create a CNAME entry to the subdomain. See the
Amazon S3 documentation for more details on how to associate domain names
with your website.7
• You can configure a default page that users will see if they visit the
domain name directly (without specifying a specific page). 8 You can also
specify a custom “404 - Page Not Found” error page if the user stumbles
onto a non-existent page.
• By default, logging is disabled. You can enable it to give you access to the
raw web access logs. 9
Page 8 of 44
Amazon Web Services – Hosting Static Websites on AWS
• Add tags to your Amazon S3 bucket. These tags will be useful later on
when you want to analyze your AWS spend by project. 10
A quick note about Amazon S3 object naming: In Amazon S3, a bucket is
a flat container of objects. It doesn’t provide a hierarchical organization the way
the file system on your computer does. However, there is a straightforward
mapping between a file system’s folders/files to Amazon S3 objects. The
example that follows shows how folders/files are mapped to Amazon S3 objects.
Most third-party tools, as well as the AWS Management Console and AWS
Command Line Interface (AWS CLI), will handle this mapping transparently for
you. However, it’s good to be aware of this fact. 11 It’s also a good habit to use
lower-case characters for file and folder names. Case is important and simply
easier to manage when all characters are lowercase.
├─ css/ css/
│ ├─ main.css css/main.css
│ └─ navigation.css css/navigation.com
├─ images/ images/
│ ├─ banner.jpg images/banner.jpg
│ └─ logo.jpg images/logo.jpg
├─ index.html index.html
├─ scripts/ scripts/
│ ├─ script1.js scripts/script1.js
│ └─ script2.js scripts/script2.js
├─ section1.html section1.html
└─ section2.html section2.html
Uploading Content
On AWS, uploading content is straightforward. Continue to design your static
website using your website authoring tool of choice. Most web design and
authoring tools can save the static content on your local hard drive. Then simply
upload the HTML, images, JavaScript files, CSS files, and other static assets into
your Amazon S3 bucket. The deployment process consists of a single step: copy
any new or modified files to the Amazon S3 bucket. You can use the AWS API,
SDKs, or CLI to script this step for a fully automated deployment.
You can upload files using the AWS Management Console. You can also use
AWS partner offerings such as CloudBerry, S3 Bucket Explorer, S3 Fox, and
Page 9 of 44
Amazon Web Services – Hosting Static Websites on AWS
other visual management tools. The easiest way, however, is to use the AWS
CLI. 12 The s3 sync command will recursively upload files and synchronize your
Amazon S3 bucket with your local folder. 13
{
"Version":"2012-10-17",
"Statement":[{
"Sid":"PublicReadGetObject",
"Effect":"Allow",
"Principal": "*",
"Action":["s3:GetObject"],
"Resource":["arn:aws:s3:::S3_BUCKET_NAME_GOES_HERE/*"]
}
]
}
This policy defines who can view the contents of your Amazon S3 bucket. In the
“Managing Administrative Access to Your AWS Resources” section of this
whitepaper, there’s a description of the use of AWS Identity and Access
Management (IAM) policies to manage permissions for your team members.
Together, Amazon S3 bucket policies and IAM policies give you fine-grained
control over who can manage and view your website.
Page 10 of 44
Amazon Web Services – Hosting Static Websites on AWS
When you use Amazon S3, you pay for what you use. You’re only charged for the
actual Amazon S3 storage required to store the site assets. 14 These assets include
HTML files, images, JavaScript files, CSS files, videos, audio files, and any other
downloadable files. Your bandwidth charges will depend on the actual site
traffic. 15 Small websites with few visitors will have minimal hosting costs.
Popular websites that serve up large videos and images will incur higher
bandwidth charges. The Estimating and Tracking AWS Spend section of this
whitepaper describes how you can estimate and track your costs.
With Amazon S3, experimenting with new ideas is easy and cheap. If a website
idea turns out to be a dud, the costs will be minimal. This should encourage you
to experiment more frequently. As they say, “fail fast, fail often!” This is great for
micro-sites – publish many independent micro-sites at once, run A/B tests, and
keep only the winners.
You’ve learned the basics of hosting a static website in Amazon S3. The
architecture is refreshingly simple: no servers—just a single Amazon S3 bucket.
It’s ready to meet the real-world demands of a high-traffic website. It’s highly
available, resilient, scalable, and cost-efficient.
Now you’ll learn how to iterate on this core architecture and make it faster,
improve its performance for international visitors, and lower its cost even
further.
Page 11 of 44
Amazon Web Services – Hosting Static Websites on AWS
• FACTOR (2) Timeit takes for Amazon S3 to retrieve the page contents and
serve up the page.
• FACTOR (3) Time it takes for the page contents (US West (Oregon) Region)
to be delivered across the Internet to the browser (Singapore).
• FACTOR (4) Time it takes for the browser to parse and display the web
page.
Page 12 of 44
Amazon Web Services – Hosting Static Websites on AWS
The good news is that AWS has already taken care of FACTOR (2) by optimizing
Amazon S3 to serve up content as quickly as possible. You can improve FACTOR (4)
by optimizing the actual page content (e.g., minifying CSS and JavaScript, using
efficient image and video formats). However, page-loading studies consistently
show that most latency is due to FACTOR (1) and FACTOR (3). Most of the delay in
accessing pages over the Internet is due to the round-trip delay associated with
establishing TCP connections (the infamous three-way TCP handshake) and the
time it takes for TCP packets to be delivered across long Internet distances.
To sum up: serve content as close to your users as possible. In our example,
American users will experience relatively fast page load times, whereas
Singaporean users will experience slower page loads. Ideally, for the
Singaporean users, you would want to serve up content as close to Singapore as
possible.
Page 13 of 44
Amazon Web Services – Hosting Static Websites on AWS
As a CDN, Amazon CloudFront can distribute content with low latency and high
data transfer rates.16 As of March 2017, there are over 70 CloudFront edge
locations all around the world. 17 Therefore, no matter where a visitor lives in the
world, there is an Amazon CloudFront edge location that is relatively close
(from an Internet latency perspective).
The Amazon CloudFront edge locations will cache content from an origin server
and deliver that cached content to the user. When creating an Amazon
CloudFront distribution, specify your Amazon S3 bucket as the origin server.18
The Amazon CloudFront distribution itself will have a DNS. You can refer to it
using a CNAME if you have a custom domain name. To point the A record of a
root domain to an Amazon CloudFront distribution, you can use Amazon Route
53 alias records, as illustrated in Figure 6.
Page 14 of 44
Amazon Web Services – Hosting Static Websites on AWS
content, CloudFront will pull a copy from the Amazon S3 origin server and hold
it at the edge location to fulfill future requests. Subsequent users requesting the
same content from that edge location will experience faster page loads because
that content is already cached. Figure 7 shows the flow in detail. In the
“Controlling How Long Amazon S3 Content Is Cached by Amazon CloudFront”
section later in this whitepaper, we cover advanced strategies.
Page 15 of 44
Amazon Web Services – Hosting Static Websites on AWS
Amazon CloudFront reports can be used alongside other online analytics tools,
and we encourage the use of multiple reporting tools. Note that some analytics
tools might require you to embed client-side JavaScript in your HTML pages.
Amazon CloudFront reporting does not require any changes to your web pages.
Figure 8 shows a sampling of types of Amazon CloudFront reports.
Page 16 of 44
Amazon Web Services – Hosting Static Websites on AWS
Page 17 of 44
Amazon Web Services – Hosting Static Websites on AWS
Page 18 of 44
Amazon Web Services – Hosting Static Websites on AWS
For any website serving a global user base, we highly recommend using Amazon
CloudFront. 19 Amazon S3 is solid on its own, and adding Amazon CloudFront
will help you deliver a higher-quality experience to your users.
Let’s now turn our attention to advanced topics. We cover the following in the
remaining sections:
Page 19 of 44
Amazon Web Services – Hosting Static Websites on AWS
DNS queries to the $0.400 per million queries Most static websites will be well below 1
Amazon Route 53 hosted for the first 1 Billion billion queries / month.
zone queries
Amazon S3 storage costs $0.023 per GB/month, for Most static websites will be well below a
the first TB of data stored TB of storage. Therefore, unless your
website contains thousands of large video
files, your Amazon S3 monthly storage
costs will $0.023 for each GB in your
Amazon S3 bucket each month.
HTTP requests to Every 10,000 HTTP Popular websites will cost more to run, of
CloudFront requests is $0.0075 course. Note that if a web page
references other assets such as images,
JavaScript scripts, and CSS files this will
result in multiple HTTP requests to
CloudFront/S3.
Data transfer from Amazon $0.085/month for the first Most static websites will be well below 10
CloudFront to end users 10 TB TB of outbound data transfer. Popular
websites will cost more to run, of course.
Page 20 of 44
Amazon Web Services – Hosting Static Websites on AWS
** As of March 2017 pricing. Also keep in mind that AWS pricing is Region-specific.
Plug your own assumptions into the AWS Simple Monthly Calculator. You might
be pleasantly surprised. Most static websites will cost less than a dollar a month
to host using Amazon S3 with Amazon CloudFront and Amazon Route 53.
Generally speaking, your AWS spend should be in the range of a few dollars at
most, and the vast majority of static websites will not require AWS spend
optimization. 25
Are you curious how your costs changed since your last marketing blitz? Simply
define a custom filter based on time and services. After you configure it just the
way you want, remember to save the report for future use. 26
Page 21 of 44
Amazon Web Services – Hosting Static Websites on AWS
Your website content should be managed using version control software (such
as Git, Subversion, or Microsoft Team Foundation Server) to make it possible to
revert to older versions of your files. 27 AWS offers a managed source control
service called AWS CodeCommit that makes it easy to host secure and private
Git repositories. Regardless of which version control system your team uses,
consider tying it to a continuous build/integration tool so that your website will
automatically update whenever the content changes.
For example, if your team is using a Git-based repository for version control, a
Git post-commit hook can notify your continuous integration tool (e.g., Jenkins)
of any content updates. At that point, your continuous integration tool can
perform the actual deployment to synchronize the content with Amazon S3
(using either the AWS CLI or the Amazon S3 API), and notify the user of the
deployment status. Setting up continuous deployment will streamline the
process for keeping content fresh, and we highly recommend it as a best
practice.
Page 22 of 44
Amazon Web Services – Hosting Static Websites on AWS
If you don’t want to use version control, then be sure to periodically download
your website and back up that snapshot. The AWS CLI lets you download your
entire website with a single command:
Access Logs
Access logs can help you troubleshoot or analyze traffic coming to your site.
Both Amazon CloudFront and Amazon S3 give you the option of turning on
access logs. There’s no extra charge to enable logging, other than the storage of
the actual logs. The access logs are delivered on a best-effort basis; they are
usually delivered within a few hours after the events are recorded.
Analyzing Logs
Amazon S3 access logs are deposited in your Amazon S3 bucket as plain text
files. Each record in the log files provides details about a single Amazon S3
access request, such as the requester, bucket name, request time, request action,
response status, and error code, if any. You could open individual log files in a
text editor.
However, it’s generally far better and easier to use one of the many third-party
tools that can interpret the Amazon S3 access log format.
If you prefer to build out a custom analytics solution, AWS Lambda and Amazon
Elasticsearch Service (Amazon ES) can help. AWS Lambda functions can be
hooked to an Amazon S3 bucket to detect when new log files are available for
processing.28 AWS Lambda function code can process the log files and send the
data to an Amazon ES cluster. Users can then analyze the logs by querying
Amazon ES or using the Kibana visual dashboard. Both AWS Lambda and
Amazon ES are managed services, and there are no servers to manage.
Page 23 of 44
Amazon Web Services – Hosting Static Websites on AWS
An AWS best practice is to archive files into Amazon Glacier, which you can
think of as a lower-cost distant cousin of Amazon S3. Amazon Glacier is suitable
for long-term storage of infrequently accessed files. Like Amazon S3, Amazon
Glacier is also designed for 99.999999999% data durability, and you have
practically unlimited storage. The difference is in retrieval time. Amazon S3
supports immediate file retrieval. With Amazon Glacier, after you initiate a file
retrieval request, there will be a delay before you can start downloading the
files. As long as you understand that tradeoff, Amazon Glacier is a terrific choice
for archiving old logs. In the US West (Oregon) Region (us-west-2) for example,
Amazon Glacier storage costs are just $0.004 per GB each month—significantly
cheaper than S3, disks, or tape drives (pricing as of March 2017).
The easiest way to archive data into Amazon Glacier is to use Amazon S3
lifecycle policies. 29 The lifecycle policies can be applied to an entire Amazon S3
bucket or to specific objects within the bucket (e.g., only the log files). A minute
Page 24 of 44
Amazon Web Services – Hosting Static Websites on AWS
• Lifecycle policy #1: After X days, automatically move logs from Amazon
S3 into Amazon Glacier.
• Lifecycle policy #2: After Y days, automatically delete logs from Amazon
Glacier.
Page 25 of 44
Amazon Web Services – Hosting Static Websites on AWS
You can create multiple IAM users under your AWS account, each with their
own login and password. 33 An IAM user can be a person, service, or application
that needs access to your AWS resources (in this case, Amazon S3 buckets,
Amazon CloudFront distributions, and Amazon Route 53 hosted zones). 34 You
can then organize them into IAM groups based on functional roles. When an
IAM user is placed in an IAM group, it will inherit the group’s permissions.
The fine-grained policies of IAM allow you to grant administrators the minimal
privileges needed to accomplish their tasks. The permissions can be scoped to
specific Amazon S3 buckets and Amazon Route 53 hosted zones.
Page 26 of 44
Amazon Web Services – Hosting Static Websites on AWS
• Super_Admins
• Super_Admins
• Network_Admins
• Super_Admins
• Network_Admins
• Website_Admin
• Super_Admins
• Website_Admin
• Super_Admins
• Website_Admin
• Website_Content_Manager
An IAM user can belong to more than one IAM group. For example, if someone
needs to manage both Amazon Route 53 and Amazon S3, that user can belong to
both the Network_Admins and the Website_Admins groups.
The best practice is to require all IAM users to rotate their IAM passwords
periodically. Multi-factor authentication (MFA) should be enabled for any IAM
user account with administrator privileges.
Page 27 of 44
Amazon Web Services – Hosting Static Websites on AWS
You can use AWS CloudTrail to see an audit trail for API activity in your AWS
account. Toggle it on for all AWS Regions, and the audit logs will be deposited to
an Amazon S3 bucket. You can use the AWS Management Console to search
against API activity history. Or you can use a third-party log analyzer to analyze
and visualize the CloudTrail logs.
Do you want to build a custom analyzer instead? You can start by configuring
CloudTrail to send the data to Amazon CloudWatch Logs. CloudWatch Logs
allows you to create automated rules that notify you of suspicious API activity.
CloudWatch Logs also has seamless integration with Amazon ES, and you can
configure the data to be automatically streamed over to a managed Amazon ES
cluster. Once the data is in Amazon ES, users can query against that data
directly or visualize the analytics using a Kibana dashboard.
So how long does a CloudFront edge location keep an item in its cache before
expiring it? CloudFront will typically serve cached content from an edge location
until the content expires. After it expires, the next time that content is requested
Page 28 of 44
Amazon Web Services – Hosting Static Websites on AWS
by an end user, CloudFront will go back to the Amazon S3 origin server to fetch
the content and then cache it. CloudFront edge locations automatically expire
content after Maximum TTL seconds elapse (by default, this is 24 hours).
However, it could be sooner because CloudFront reserves the flexibility to expire
content if it needs to, before the Maximum TTL is reached. By default, the
Minimum TTL is set to 0 (z er o) seconds, and that’s configurable as well. So to
be more accurate, CloudFront may expire content anytime between the
Minimum TTL (default is 0 seconds) and Maximum TTL (default is 24 hours).
For example, if Minimum TTL=60s and Maximum TTL=600s, then content will
be cached for at least 60 seconds and at most 600 seconds.
For example, say you deploy updates to your marketing website, with the latest
and greatest product images. After uploading your new images to Amazon S3,
you immediately browse to your website DNS, and you still see the old images!
It is likely that one and possibly more CloudFront edge locations are still
holding onto cached versions of the older images and serving the cached
versions up to your website visitors. If you’re the patient type, you can wait for
CloudFront to expire the content, but it could take up to Maximum TTL seconds
for that to happen. Often a stale website is simply not acceptable.
There are several ways to tackle this, each with its pros and cons. The first
approach is that you can set the Maximum TTL to be a relatively low value. The
tradeoff is that cached content expires faster because of the low Maximum TTL
value. This results in more frequent requests to your Amazon S3 bucket because
the CloudFront caches need to be repopulated more often. In addition, the
Maximum TTL setting applies across the board to all CloudFront files, and for
some websites you might want to control cache expiration behaviors based on
file types.
The second approach is to implement content versioning. Every time you update
website content, embed a version identifier in the file names. It can be a
timestamp, a sequential number, or any other way that allows you to distinguish
between two versions of the same file. For example, instead of banner.jpg, call
it banner_20170401_v1.jpg. When you update the image, name the new
version banner_20170612_v1.jpg and update all files that need to link to the
new image. 36
In the following example, the banner and logo images are updated and receive
new file names. However, because those images are referenced by the HTML
Page 29 of 44
Amazon Web Services – Hosting Static Websites on AWS
files, the HTML markup also needs to be updated to reference the new image file
names. Note that the HTML file names shouldn’t have version identifiers in
order to provide stable URLs for end users.
├─ css/
│ ├─ main_20170401_v1.css
│ └─ navigation_20170401_v1.css
├─ images/
│ ├─ banner_20170401_v1.jpg
│ └─ logo_20170401_v1.jpg
├─ index.html/
├─ scripts/
│ ├─ script1_20170204_v1.js
│ └─ script2_20170204_v1.js
├─ section1.html
└─ section2.html
├─ css/
│ ├─ main_20170401_v1.css
│ └─ navigation_20170401_v1.css
├─ images/
│ ├─ banner_20170612_v1.jpg
│ └─ logo_20170612_v1.jpg
├─ index.html
├─ scripts/
│ ├─ script1_20170204_v1.js
│ └─ script2_20170204_v1.js
├─ section1.html
└─ section2.html
Page 30 of 44
Amazon Web Services – Hosting Static Websites on AWS
The main challenge is that content update processes will need to be “version-
aware.” File names will need to versioned. Files with references to changed files
will also need to be updated. For example, if an image is updated, the following
need to be updated as well:
• Content in any HTML, CSS, and JavaScript files referencing the older
image file name
• The file names of any referencing files (with the exception of HTML
files)
A few static site generator tools can automatically rename file names with
version identifiers, but most tools aren’t version-aware. Manually managing
version identifiers can be cumbersome and error-prone. If your website would
benefit from content versioning, it might be worth investing in a few automation
scripts to streamline your content update process.
Page 31 of 44
Amazon Web Services – Hosting Static Websites on AWS
In practice, you should automate this as part of your Amazon S3 upload process.
If you’re using the AWS CLI, as we recommended earlier, a small tweak to your
deployment scripts will do the trick:
The best practice is to understand and use the four approaches together. If
possible, implement content versioning. It allows you to immediately review
changes and gives you the most precise control over the CloudFront and
Amazon S3 experience. Set the Minimum TTL to be 0 seconds and the
Maximum TTL to be a relatively low value. Also, use Cache-Control headers
for individual pieces of content. If your website is infrequently updated, then set
a large value for Cache-Control:max-age=<seconds> and then issue
Page 32 of 44
Amazon Web Services – Hosting Static Websites on AWS
CloudFront invalidation requests every time your site is updated. If the website
is updated more frequently, use a relatively small value for Cache-
Control:max-age=<seconds> and then issue CloudFront invalidation
requests only if the Cache-Control:max-age=<seconds> settings exceeds
several minutes.
Conclusion
This whitepaper started with a look at traditional (non-AWS) architectures for
static websites. We then showed you an AWS Cloud-native architecture based on
Amazon S3, Amazon CloudFront, and Amazon Route 53.
The AWS architecture is highly available and scalable, secure, and provides for a
responsive user experience at very low cost. By enabling and analyzing the
available logs, you can you understand your visitors and how well the website is
performing. Fewer moving parts means less maintenance is required. In
addition, the architecture costs only a few dollars a month to run.
Contributors
The following individuals and organizations contributed to this document:
Notes
1 http://docs.aws.amazon.com/AmazonS3/latest/dev/WebsiteHosting.html
2 Each S3 object can be 1 byte to 5 TB in file size, and there’s no limit to the
number of Amazon S3 objects you can store.
3 http://aws.amazon.com/s3/sla/
4 For a list of available AWS Regions, visit: http://aws.amazon.com/about-
aws/global-infrastructure/. For an overview of AWS Regions and Availability
Zones, visit http://aws.amazon.com/about-aws/global-infrastructure/. If your
high-availability requirements require that your website must remain available
even in the case of a failure of an entire AWS Region, you might want to
Page 33 of 44
Amazon Web Services – Hosting Static Websites on AWS
http://docs.aws.amazon.com/AmazonS3/latest/dev/IndexDocumentSupport.
html
12 http://aws.amazon.com/cli/
13 Refer to http://docs.aws.amazon.com/cli/latest/reference/s3/sync.html for
more details on the AWS CLI command. For moving very large quantities of
data, there are alternative methods of moving large numbers of large files into
S3: https://aws.amazon.com/s3/cloud-data-migration/
14 http://docs.aws.amazon.com/AmazonS3/latest/dev/BucketBilling.html
15 More specifically, the number of bytes that are delivered to the website visitor
in the HTTP responses.
16 In addition to ensuring that end-user requests are served by the closest edge
location, Amazon CloudFront also keeps persistent connections with your
origin servers so that those files can be fetched from the origin servers as
quickly as possible. Finally, Amazon CloudFront uses additional optimizations
(e.g., wider TCP initial congestion window) to provide higher performance
while delivering your content to viewers.
17 http://aws.amazon.com/cloudfront/details/
18
http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/Mi
grateS3ToCloudFront.html
Page 34 of 44
Amazon Web Services – Hosting Static Websites on AWS
Page 35 of 44
Amazon Web Services – Hosting Static Websites on AWS
29 https://aws.amazon.com/blogs/aws/amazon-s3-lifecycle-management-
update/
30 https://aws.amazon.com/whitepapers/aws-security-best-practices/
31
http://docs.aws.amazon.com/AmazonS3/latest/dev/UsingServerSideEncrypti
on.html
32 http://blogs.aws.amazon.com/security/post/Tx4BUZIS3E2QG2/Make-a-
New-Year-s-Resolution-Adhere-to-IAM-Best-Practices
33 The AWS account is the account that you create when you first sign up for
AWS. Each AWS account has root permissions to all AWS resources and
services. The best practice is to enable multi-factor authentication (MFA) for
your root account, and then lock away the root credentials so that no person or
system uses the root credentials directly for day-to-day operations. Instead,
create IAM groups and IAM users for the day-to-day operations.
34 through the AWS Management Console, command line tools, or APIs
35
http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/Ex
piration.html
36
http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/Re
placingObjects.html
37
http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/Ex
piration.html
38
http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/Inv
alidation.html
Page 36 of 44