# Docker Setup

If you just want a ready to go docker environment you can just use the quickstart, do read on though if you're after more detail.

# Pre-requisites

# Pre-requisites for Windows systems

# Pre-requisites for all systems

# Env Vars

You will also need to set up a bunch of environment variables

# .env

Create a .env file based on .env.dist.

On Linux systems you will want to set USER_ID and GROUP_ID to the uid/gid of your primary user. These do not need to be set on Windows/Mac systems.

# ./docker/database/.env

Create the .env file baed on .env.dist.

It is recommended to change the default passwords even for development environments.

# ./docker/app/.env

Create the .env file based on .env.dist.

It is recommended to change the default passwords even for development environments.

Env vars declared here will override any vars declared in the .env file in the root. See the header comment within the root .env.dist for an explanation as to why, baring in mind that in this context the 'real' environment is docker.

# Hosts file entries

127.0.0.1 $PROJECT_NAME.local

If you want to change this you can, but you will need to make a change to WP_HOME in ./docker/app/.env.

# Create environment

  • docker network create --subnet=192.168.35.0/24 $DOCKER_NETWORK_NAME

The docker network is required to ensure the loopback works with the expected IP address.

  • docker-compose build

This only needs to be called once to build the image(s)

  • Use docker-compose up to build the containers. You'll only need to use this the first time.

  • Use docker-compose start to start the container

  • Use docker-compose stop to stop the container (without removing the volumes).

Using docker-compose down stops containers but also removes them. This will lead to loss of data (e.g. your database).

That's it! You should now be able to browse to https://$PROJECT_NAME.local (or whatever you set) and view the site. Note, at time of writing you will need to go through the install script to have WordPress set up.

# Running with Mac (And Docker Desktop)

# Xdebug

We are running 2 app containers. By default, you will be using an xdebug-free container. This speeds up local env in browser and CLI as they no longer run xdebug for every request.

Setup

Settings
Settings

  • Ensure your IDE is set up correctly. Screenshots below show PhpStorm setup as an example.

Settings
Settings

Debugger
Debugger

Server
Server

  • To run xdebug in the browser: enable it in your IDE; add breakpoints; then go to your browser; enable xdebug in the browser extension (from first step of the setup) and reload the page.
  • To run xdebug in CLI: enable it in your IDE; add breakpoints; then execute the CLI command:
     docker-compose exec --user www-data app_xdebug php index.php

Or, use one of the helper scripts located in ./bin/docker/xdebug

On linux, remember to set remote_host to 192.168.35.1

# Running composer or wp-cli

If you wish to run composer or wp-cli there are two bin scripts that will allow you to run directly on the container:

bin/docker/composer bin/docker/wp