DEV Community

Colin Duggan for AWS Community Builders

Posted on • Updated on

Hosting a static WordPress Site on AWS S3

AWS S3 is a good choice for hosting static WordPress sites. It's secure and inexpensive, and frees up time which would otherwise be spent ensuring plugins, themes, and security procedures were appropriately configured.

The article describes one approach for generating the static site. The local development environment requires Docker Compose, and the only requisite plugin is the Simply Static WP Plugin, which exports the static site to a zip file before being uploading to S3.

Prerequisites

  • Docker Engine
  • Docker Compose
  • S3 bucket configured to host a static website

Preparing the WordPress Site

A quick start guide for running WordPress with Docker Compose can be found at docs.docker.com. I've included the reference docker-compose.yml file included in that startup guide in the snippet below. It can be used to build a local WordPress instance by running the command docker-compose up -d. The resulting containerized version of WordPress will be available at http://localhost:8000.

version: "3.9"

services:
  db:
    image: mysql:5.7
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: somewordpress
      MYSQL_DATABASE: wordpress
      MYSQL_USER: wordpress
      MYSQL_PASSWORD: wordpress

  wordpress:
    depends_on:
      - db
    image: wordpress:latest
    extra_hosts:
      - localhost:172.23.0.3
      - localhost:172.23.0.1
    volumes:
      - wordpress_data:/var/www/html
    ports:
      - "8000:80"
    restart: always
    environment:
      WORDPRESS_DB_HOST: db
      WORDPRESS_DB_USER: wordpress
      WORDPRESS_DB_PASSWORD: wordpress
      WORDPRESS_DB_NAME: wordpress
volumes:
  db_data: {}
  wordpress_data: {}
Enter fullscreen mode Exit fullscreen mode

Export Static Site

The static site generation part of this work can begin once the WordPress site has been fully configured. Configuration includes selection of the site's theme. Installation of plugins which support the site's functionality. Addition of site specific content, as well as any other customizations required to produce the final result.

  • 1 Navigate to _Plugins\Add New_ and search for _Simply Stati_c.

Image description

  • 2 Once installed, navigate to Simply Static\Settings and ensure the following options are configured for destination URLs and delivery method

Image description

  • 3 Update the location for Temporary Files by navigating to Simply Static\Settings\Advanced. (This path will write to our wordpress_data volume)

Image description

  • 4 Generate static files by navigating to Simply Static\Generate and clicking the Generate Static Files button

Image description

  • 5 Once step 4 is complete, click the link to download the static content. Inspect the contents of the .zip file. It should include the following items
  1. - index.html
  2. - wp-content/
  3. - wp-includes/

Uploading to AWS S3

In this step, output from running the Simply Static Plugin, is uploaded to S3.

At the point, the S3 bucket should be configured for static website hosting. This can be enabled through all the usual AWS paths (REST API, SDK, CLI, CloudFormation). We will be sticking with the console.

  • Click on the S3 bucket. Navigate to the Properties tab. Scroll down to the section titled Static website hosting. Enable and select Host a static website as the hosting type. Update the Index document field with the index.html landing page. Save changes.

Image description
Now upload the contents of the Zip file (index.html, wp-content, wp-includes) using the Upload option on the S3 bucket landing page.

The shiny new static WordPress site will now be accessible using the public URL for the site (available under the Properties tab for the S3 bucket under the section Static website hosting).

Secure S3 Bucket with Origin Access Identity (OAI)

Image description

The S3 bucket can be secured behind a CloudFront distribution to give greater control over access to the S3 bucket. The S3 bucket should be marked private. An Origin Access Identity (OAI) will be created and associated with a CloudFront distribution. The S3 bucket permissions are then updated to allow the CloudFront distribution to use the OAI to access the static site. The following snippet illustrates the bucket policy which will allow the CloudFront distribution access. Full details can be found on docs.aws.amazon.com.

{
    "Version": "2012-10-17",
    "Id": "PolicyForCloudFrontPrivateContent",
    "Statement": [
        {
            "Effect": "Allow",
            "Principal": {
                "AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity <distribution ID>"
            },
            "Action": "s3:GetObject",
            "Resource": "arn:aws:s3:::<s3-bucket>/*"
        }
    ]
}
Enter fullscreen mode Exit fullscreen mode

Future Enhancements

The previous guide acts as an introduction to getting a static WordPress site up and running in AWS. In a follow-up article, I refine this current setup and include automation for building and deploying to S3. If you have any comments or suggestions on how this process could be refined, please leave them in the comments section below.

Top comments (2)

Collapse
 
allanchua101 profile image
Allan Chua

Hi Thanks for the cool article!
Did you manage to get the CI/CD of simply static working?

Collapse
 
stoyanscava profile image
Stoyan Georgiev

I'm super hyped about the CI/CD follow up!