Skip to content

Running Wordpress on Docker with the PHP Code, Plugins, and Themes in Version Control

Notifications You must be signed in to change notification settings

polyverse/docker-wordpress

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DEPRECATION NOTICE

Please note that this repository has been deprecated and is no longer actively maintained by Polyverse Corporation. It may be removed in the future, but for now remains public for the benefit of any users.

Importantly, as the repository has not been maintained, it may contain unpatched security issues and other critical issues. Use at your own risk.

While it is not maintained, we would graciously consider any pull requests in accordance with our Individual Contributor License Agreement. https://github.com/polyverse/contributor-license-agreement

For any other issues, please feel free to contact [email protected]


Wordpress on Docker

This repository shows how to run Wordpress on Docker while keeping the PHP code, plugins, and themes within source control. This has advantages to running Wordpress out of a shared file system. This enables Wordpress, Custom Code, and the PHP configuration to be tested a single unit prior deploying to production. This does have limitations which is documented below.

Note: This repository is meant to be an example and should not be used in production without testing your application against this configuration.

Limitations

  • Wordpress Core, Plugins, and Themes work across containers by persisting them in the /wordpress folder.
  • This assumes all dynamic content is stored in the /uploads folder

Getting Started

This repo shows how you can build the container using arbitrary versions of Wordpress. This functionality is defined using make. The IMAGE_NAME, IMAGE_TAG, WORDPRESS_VERSION, and WORDPRESS_SHA1 can be overridden with custom values.

# this will use the default version of Wordpress defined in the Makefile
make build

# define a custom version of Wordpress, these can be found https://wordpress.org/download/releases/
make WORDPRESS_VERSION=5.2.5 WORDPRESS_SHA1=1afb2e9a10be336773a62a120bb4cfb44214dfcc build

Polyscripted PHP for defense against Code-Injections

This container also optionally provides Polyverse's open source Polyscripting defense for PHP. This is merely enabled by adding an environment variable "MODE=polyscripted" to the wordpress container.

The details on Polyscripting can be found at this link: https://polyverse.com/polyscripting

Quick Summary:

  • Polyscripting stops runtime-injected code from being executed.
  • PHP and particularly Wordpress websites are susceptible to code-injection attacks frequently.
  • Polyscripting does this by generating a new PHP-derived language on-the-fly just before the container serves requests, and then transforming the entire wordpress code to this new language.
  • This is different from obfuscation because the language itself is changing.

Limitations

In Polyscripted mode, the wordpress instance cannot be updated and new plugins cannot be installed because the code is closed for modification. It is recommended to start a container in non-polyscripted mode, perform maintenance, and restart in polyscripted mode for safety.

In real-life production use, it is possible to start an internal-only unpolyscripted instance with the shared volume, performing maintenance and then restarting the external-facing polyscripted instances to pick up the changes.

Testing Polyscripting defense

You can view an online-demo here: https://polyverse.com/learn/polyscripted-wordpress/

You can also place this trivially-remotely-injectable page in your wordpress folder:

<?php
$myvar = "varname";
$x = $_GET['arg'];
eval("\$myvar = \$x;");
?>

And you can call (adjusted for your endpoint): https://localhost:8080/hack.php?arg=1%3B%20echo%20phpinfo%28%29%3B

You'll find phpinfo() is echo'd on a non-polyscripted endpoint, but generates a syntax error on a polyscripted endpoint.

Deployment

This container is designed to be deployed to multiple orchestration systems such as Amazon ECS or Kubernetes. The container has two requirements for storage to be mounted for persistence. This is so that when users upload images they will be persisted and can be shared across containers. I recommend using a NFS based volume such as Amazon EFS.

  • /wordpress - for storing wordpress files (plugins, updates, etc.) are persisted across containers
  • /uploads - for storing uploaded images and persisted across containers

Kubernetes on Amazon EKS

This file shows you how to deploy this container to Amazon EKS. You will need the following controllers installed on your cluster:

Before getting started, deploy a cluster to AWS, provision a RDS database, and create an EFS File System with mount points in each AZ.

Next, go to the examples/kubernetes.yml file and update the PersistentVolume configuration with the ID of the EFS File System you created.

Next create a secret for all of the Wordpress Salts (These can be genereated here). These will enable all instances of our pods to encrypt and decrypt the session.

kubectl create secret generic wordpress-salts \
    --from-literal=auth_key="" \
    --from-literal=secure_auth_key="" \
    --from-literal=logged_in_key="" \
    --from-literal=nonce_key="" \
    --from-literal=auth_salt="" \
    --from-literal=secure_auth_salt="" \
    --from-literal=logged_in_salt="" \
    --from-literal=nonce_salt="

Then we need to create another secret for our Wordpress Database configuration.

kubectl create secret generic wordpress-db \
  --from-literal=host="" \
  --from-literal=name="" \
  --from-literal=username="" \
  --from-literal=password=""

Then finally,

kubectl apply -f examples/kubernetes.yml

If you wish to configure a TLS Certificate you can add an annotation to this example. The additional annotations are documented on the ALB Ingress docs.

Docker Compose

This file is an exmaple that you can run locally and shows how to deploy Wordpress using Docker Compose. This requires that you have Docker Desktop installed. The container build is defined in the Docker Compose for usability purposes.

Note: The first time you boot the database it will take time to initialize. Wordpress will keep restarting until the database is available.

# OPTIONAL: Start wordpress with Polyscripting enabled
MODE=polyscripted
# start wordpress, the site will be available at http://localhost:8080
docker-compose -f ./examples/docker-compose.yml -p wordpress up

# tear the application down
docker-compose -f ./examples/docker-compose.yml -p wordpress down

About

Running Wordpress on Docker with the PHP Code, Plugins, and Themes in Version Control

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • CSS 57.0%
  • PHP 33.9%
  • JavaScript 6.5%
  • Shell 1.8%
  • Other 0.8%