Using S3 and Cloudfront to serve up images
Tutorial is done on OSX – adjust for your ecosystem. An Amazon Web Services (AWS) and DNS account is assumed.
- From the AWS console, create a new or use an existing S3 bucket. I'll use an existing bucket named 'minimul-images'
- Click the magnifying glass icon to the bucket's left to display the bucket properties.
- Click on 'Edit bucket policy'
- Replacing your bucket name, cut and paste the following JSON inside of the popup policy editor. This gives the proper public access permissions to all sub-folders of the bucket.
- Set up
s3cmd
- Upload some files
- From the AWS console, create a new Cloudfront distribution.
- Click 'Continue' on the next screen to create a web distribution.
- Choose
YOUR-BUCKET-NAME.s3.amazonaws.com
from the dropdown for 'Origin Domain Name'. Also, add a CNAME likeimg.YOUR-DOMAIN-NAME.com
- Click 'Create Distribution' and wait until the status goes from 'inProgress' to 'Deployed'.
- Set up the CNAME at your DNS provider.
- Get the Cloudfront domain name.
- Add CNAME entry
- After the CNAME record has propagated try to access the image e.g.
https://d38ux1iykvusrb.cloudfront.net/articles/112/s3-cloudfront-distro-deployed.png
- Congrats, you are serving up images via Amazon's Cloudfront CDN.
data:image/s3,"s3://crabby-images/346b9/346b91f1c3539a02576743bf7e08c31aedcecbe9" alt=""
data:image/s3,"s3://crabby-images/13ca8/13ca819e8d15a0d04b650b8a961afca95f9f162a" alt=""
{ "Version": "2008-10-17", "Id": "Policy1342052196146", "Statement": [ { "Sid": "Stmt1342052192499", "Effect": "Allow", "Principal": { "AWS": "*" }, "Action": "s3:GetObject", "Resource": "arn:aws:s3:::YOUR-BUCKET-NAME/*" } ] }
data:image/s3,"s3://crabby-images/2c561/2c561b1aba1b8bd0cbb5ffcec696b3186a39b0b3" alt=""
$ brew install --devel s3cmd # installs multipart-upload-capable version of s3cmd. $ s3cmd --version s3cmd version 1.5.0-beta1 $ s3cmd --configure # Go thru the wizard and select defaults for everything # but enter in your AWS access and secret s3cmd ls s3://YOUR-BUCKET-NAME # Test
# Example s3cmd sync /public/images/articles/112 s3://minimul-images/articles/
This is will create a directory structure on s3 as such:
s3://minimul-images/articles/112
. Because there is no trailing slash after the 112
, this directory will be created. The articles
directory will also be created if it does not exist.
data:image/s3,"s3://crabby-images/ceffb/ceffb3e445fb48e2ea0588497f28f6fd93d9fc82" alt=""
data:image/s3,"s3://crabby-images/56ca4/56ca41cfa9a44ac532c71b66163e9f7518d76387" alt=""
data:image/s3,"s3://crabby-images/39d8e/39d8eeeb52b8cee59c08cae68b59e03d8621e0c6" alt=""
data:image/s3,"s3://crabby-images/794d3/794d346407774eac1d2136e20432b7697da6f532" alt=""
data:image/s3,"s3://crabby-images/ad515/ad5157116ce758da0f89496a4fa5b28b57d1fd41" alt=""
data:image/s3,"s3://crabby-images/b75da/b75da6e266f706fea6a579a84e708a7c688b0ac3" alt=""
data:image/s3,"s3://crabby-images/123d0/123d0c710ec52cd82b66274547b7d4aab62520ad" alt=""
data:image/s3,"s3://crabby-images/0e8b7/0e8b7b9285a5c9da32cae55d1c35431489a02f4d" alt=""
- Pushed on 02/12/2014 by Christian