Hosting a WordPress site can be insecure and expensive. Making it static is a great way to optimize these downfalls, and hosting it in S3 can reduce costs even more and allow for more fine-grained security configurations.
The steps below will walk you through how to generate static files from your WordPress site and host them in a new and configured AWS S3 bucket for a custom domain.
By using a WordPress S3 plugin, you can easily offload your files and take advantage of Amazon Web Services’ infrastructure. While the process might take 30 minutes or so to get set up, once you’ve knocked it out the WordPress S3 integration is pretty pain-free and shouldn’t require any further work.
- Setting up Amazon S3. Make sure to install and activate the two plugins I mentioned above – Amazon Web Services and Amazon S3 and Cloudfront. Once done you should see an AWS menu entry in the WordPress admin. Clicking on it will allow you to enter your security credentials. Set your credentials in the form. (Click for a larger view.).
- Hosting a WordPress site can be insecure and expensive. Making it static is a great way to optimize these downfalls, and hosting it in S3 can reduce costs even more and allow for more fine-grained security configurations.
This is Part 2 in a series about creating a static WordPress site deployed using AWS S3 and Cloudflare:
Part 1 – Building a WordPress in Docker
Part 2 – Converting a WordPress to a Static Site and Deploying to AWS S3
Part 3 – Connecting Your S3 Bucket to Cloudflare
Wordpress S3 Media
Downloading your Static Files
Wordpress To S3
- Navigate to Plugins >Add New > Search Simply Static > Click Install > Click Activate. Once the plugin is activated, navigate to Simply Static in the side panel and select Settings.
- Under the General tab, make sure Use relative URLs is checked and the Delivery Method is set to ZIP Archive. Then click Save.
- Navigate to Simply Static >Generate and click Generate. Assuming the process completes successfully, there should be a message that says you can download your site as a .zip file. Click this link. You will need this later to upload to your AWS S3 bucket.
Configuring Your S3 Bucket
- Sign in to AWS. Navigate to S3 and create a new bucket. Give it the name of your domain. I named mine gillianlemke.com.
- There are a few steps to go through before your bucket is created. You can change any of this later in the bucket configurations.
- Click through Step 2: Configure options. Nothing special is needed here right now.
- Step 3: Set permissions is important. Uncheck all of these. In order for your site to be publicly accessible, the bucket needs lower security than you’d want otherwise.
- In Step 4, just review your bucket and then click Create.
- Next, you’ll need to create the bucket policy. AWS has this handy-dandy policy generator. Below, you can see how I filled out mine. (If you don’t want to use the generator, there are pretty good examples on the AWS docs as well.)
- Type of policy: S3 Bucket Policy
- Effect: Allow
- Principal: *
- AWS Service: Amazon S3 (this is auto-populated depending on the type of policy)
- Actions: only GetObject
- AmazonResourceName (ARN): this is dependent on your domain name but will have the same format, for example: arn:aws:s3:::gillianlemke.com/*
- You should add a condition. I only want to give Cloudflare access to my S3 bucket, so I made a condition that only allows Cloudflare IPs. All Cloudflare IP Ranges can be accessed here.
- Condition: IpAddress
- Key: aws:SourceIp
- Value: make a comma-separated list using the IPs (including the ranges) from the Cloudflare link above. (Personally, I found the generator hard to use in this step, so you might want to add these after you’ve generated the file.)
- Just to be safe, you’ll also want to add a CORS configuration with one rule allowing all GET requests access to your domain, which in this case is https://gillianlemke.com.
- The last thing you might want to do is make an S3 bucket that points to the www prefixed version of your domain. AWS has a very handy way to do this.
- Create a new S3 bucket and name it the www version of your site, example: www.gillianlemke.com. (Don’t do any fancy configurations, just click create from Step 1.)
- After you’ve created the bucket, navigate into the bucket, and go to the Properties tab.
- Click Static Website Hosting and check Redirect requests. Type in the name of your main bucket where you made all your configurations, for example gillianlemke.com, and set the protocol to https.
- In your main bucket, don’t forget to upload your website files that you downloaded at the beginning of the tutorial. To do that, click on your bucket, click upload, and drag and drop all of your WordPress files.
Here is my finished product. I did not use the generator, so yours may look slightly different depending on how you got your solution.
You’re almost there! Now that you’ve set up your S3 bucket, we just have to configure Cloudflare, and then you’ll have a static WordPress site running on AWS!