How to Install WordPress with Docker: An Easily-to-Follow Guide

This tutorial will show you how to run a WordPress installation in Docker containers by using Docker Compose.

WordPress is the most popular CMS (Content Management System) globally, which makes it a top-drawer consideration when building a new site. It is built on a MySQL database with PHP processing.

Setting up a local WordPress installation involves multiple steps and can be time-consuming. Usually, you need to set up a local web server, configure the server to execute PHP code, and set up a MySQL database.

However, the easiest way to set up a local WordPress environment is to use containerization with Docker.

1. Install Docker Compose

When using Docker extensively, managing several different containers becomes cumbersome. Docker Compose is a tool you can easily define and start multi-container applications in Docker.

With Compose, you can define all services in a single YAML file and, with a single command, can spin everything up or tear it all down.

In this tutorial, we will run two containers (WordPress and MySQL) in an isolated containerized environment using Docker Compose.

Now let me show you how to install the latest version of Docker Compose to help you manage multi-container applications.

First, check the current release and if necessary, update it in the command below:

sudo curl -L "https://github.com/docker/compose/releases/download/v2.5.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/bin/docker-composeCode language: JavaScript (javascript)

Then apply executable permissions to the binary:

sudo chmod +x /usr/bin/docker-compose

Finally, you can verify that the installation was successful by checking the version:

docker-compose --version
Installing docker-compose

For more about Docker Compose, you can refer to the official documentation.

2. Prepare Directory

You need to create a new directory called wordpress under /srv to house the WordPress data. This way, we achieve a certain data persistence.

sudo mkdir -p /srv/wordpress
cd /srv/wordpress/

As you know, the data in the Docker containers is not persistent. This means that you lose all data when you stop the container and run it again; there will no longer be any data inside.

Of course, this can be avoided by adding a Docker volume, as you’ll see later in this tutorial.

3. Creating the YAML File

In the Docker Compose realm, all the resources needed to run a container must be defined in a YAML file named docker-compose.yaml.

Docker Compose will then read such files and communicate with the Docker daemon to create, configure, or destroy the defined resources.

In our case, the docker-compose.yaml file will contain the service definitions for our dockerized WordPress setup.

In addition, Docker Compose allows us to link these services together with shared networks and volumes.

So let’s start with creating a new docker-compose.yaml file inside the /srv/wordpress directory with an editor of your choice.

sudo vim docker-compose.yamlCode language: CSS (css)

Populate it with this config:

version: '3'
services:
  mysql:
    image: mysql:latest
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: my_password
      MYSQL_DATABASE: wordpress
      MYSQL_USER: wordpress_user
      MYSQL_PASSWORD: wordpress_password
    volumes:
      - mysql_data:/var/lib/mysql
  wordpress:
    image: wordpress:latest
    depends_on:
      - mysql
    ports:
      - 8080:80
    restart: always
    environment:
      WORDPRESS_DB_HOST: mysql:3306
      WORDPRESS_DB_USER: <meta http-equiv="content-type" content="text/html; charset=utf-8">wordpress_user
      WORDPRESS_DB_PASSWORD: <meta http-equiv="content-type" content="text/html; charset=utf-8">wordpress_password
    volumes:
      - ./wp-content:/var/www/html/wp-content
volumes:
  mysql_data:Code language: PHP (php)

A little bit of explanation here:

  • We define two services, mysql and wordpress, that are automatically linked with each other.
  • They use a Docker image, which will decide which version of MySQL and WordPress to use. In this case, their latest versions.
  • MySQL environment: WordPress will use these environment variables to connect to the MySQL container.
  • WordPress environment: For a WordPress container to run, you should set the database connectivity details.
  • WordPress image is based on Apache, which runs on port 80 by default. Map the default Apache port to port 8080 of the local computer.
  • mysql_data: Data flowing into this database will be persisted to a named volume mysql_data so that even when you remove the container, the data will still live on your machine and can be mounted again inside a new container.

In addition, the volumes parameter under wordpress is what tells Docker to surface the wp-content directory in the local file system.

So we now have persistent storage for parts of our WordPress site, such as the wp-content directory. The wp-content contains all user-supplied content. So basically, anything you can upload to your site ends up here.

However, as long as you have both the database and your wp-content folder, you can always get your site back, even if everything else was lost.

4. Run WordPress with Docker Compose

Now you are ready to run the Docker command to build your local environment. Make sure you are still in the wordpress directory. Run the following command:

sudo docker-compose up -d

The command will begin running scripts, and you should see various “Downloading” and “Waiting” messages appear in the terminal while Docker pulls in the MySQL and WordPress images. This will take a little while to run.

When you keep a close eye on your local file system, you’ll see that the /srv/wordpress/wp-content folder will be created and filled with files and folders after the Docker images have been pulled in.

Install WordPress with Docker

The WordPress installation with a MySQL container and a WordPress container has been successful.

Let me now explain why we made the contents of the wp-content directory permanent, i.e., available outside of the Docker container.

When you install new themes or upload media files like images to your WordPress installation, they are saved in directories under the wp-content directory.

Because, as previously stated, containers do not retain the information stored in them after a restart, these files would be lost if the Docker container is relaunched. This is something we would never want to happen.

So, by moving the wp-content directory out of the Docker container, we ensure that the files contained within it will remain accessible once the container is restarted.

5. Access Your WordPress Installation

Finally, we can finish the installation through the WordPress web interface with our containers running. In your web browser, navigate to http://localhost:8080 or http://your_ip_address:8080.

You may need to find out your IP address using the ifconfig command.

The language selection page will greet you. Select your language and click Continue.

Select Language

Fill out the necessary information on the next screen and click “Install WordPress.”

Set Configuration

Finally, when prompted, click Login.

WordPress Had Been Successfully Installed

The standard WordPress login screen will then greet you. Once you’ve successfully authenticated, you can start using WordPress.

WordPress Admin Panel

Additional Docker Compose Options

First, make sure you are in the /srv/wordpress directory.

To view the status of a Docker application, execute the following command:

sudo docker-compose ps

You can stop all the running containers by using the following command:

sudo docker-compose stop

To start existing containers that were created with docker-compose up:

sudo docker-compose start

The command shown below will stop and remove containers and all the networks:

sudo docker-compose down

Conclusion

We introduced you to the concept behind Docker Compose, and you should now be able to define even simple multi-container applications.

In this tutorial, you used Docker Compose to install a WordPress with Docker. You now have WordPress up and running.

We hope you enjoyed reading this guide. Happy Dockering!

Bobby Borisov

Bobby Borisov

Bobby, an editor-in-chief at Linuxiac, is a Linux professional with over 20 years of experience. With a strong focus on Linux and open-source software, he has worked as a Senior Linux System Administrator, Software Developer, and DevOps Engineer for small and large multinational companies.