Description of installation and use of Docker and Docker Compose to create a temporary environment for creating a new wordpress theme in vscode. The environment consist of:
- wordpress:latest
- XDebug
- mysql 5.7
- phpmyadmin
- webpack 5
You should also install the plugin PHP Debug
Each change in the scss/js files loads the generated css and js into wordpress and automatically refreshes the page view.
Main folders are:
.vscode
└── launch.jsonlisten for XDebug
config
├── mysqldump.js
├── postcss.config.js
├── webpack.common.js
├── webpack.dev.js
└── webpack.prod.jswebpack, postcss and mysqldump - the ability to do a database dump from the command line
yarn dump
databasedatabase always used when starting the environment
docker
└── wordpress
    └── wordpress.Dockerfileconfiguration for wordpress and xdebug
dumpfolder into which the database is being dumped
yarn dump
frontend
├── images
├── js
│   ├── index.js
│   └── post.js
└── scss
    ├── global.scss
    ├── index.scss
    ├── normalize.scss
    └── post.scssthe folder contains
scss/jsfiles that are compiled and saved in the folderwp-content/themes/assets/(css|js)
wp-content
├── themes
│   ├── newTemplate
│   │   ├── assets
│   │   │   ├── css
│   │   │   └── js
│   │   ├── inc
│   │   │   └── themename_styles.scripts.php
│   │   ├── 404.php
│   │   ├── footer.php
│   │   ├── functions.php
│   │   ├── header.php
│   │   ├── index.php
│   │   ├── sidebar.php
│   │   └── style.css
└── ...new template, the most important file
themename_styles.scripts.phphe gets the css and js generated and places it in a wordpress template
Install the Docker, manual can be found here -> Docker. Linux users must also install Docker Compose separately.
git clone https://github.com/tomik23/docker-wordpress.git
cd docker-wordpress
yarnIn the created docker-wordpress folder there is docker-compose.yml Start the console and ...
docker-compose up all dependencies will be incurred, this may take a while.
yarn downall docker containers will be removed
yarn devruns the development environment at
http://localhost:3000, js/css files are generated and loaded into wordpress in the folderwp-content/themes/assets/(css|js)
yarn prodfinally generated
css/jsfiles with separate portions, in the same folder as devwp-content/themes/assets/(css|js), but this time they are compressed
yarn dumpdumps the database,
- wordpress http://localhost:3000
- wp-admin http://localhost/wp-admin(user/password test)
- phpMyAdmin http://localhost:8001(user root, password test)
Example configuration file docker-compose.yml:
version: '3.7'
services:
  db:
    image: mysql:5.7
    container_name: mysql
    volumes:
      - ./database:/docker-entrypoint-initdb.d
    ports:
      - 3306:3306
    restart: on-failure
    environment:
      MYSQL_ROOT_PASSWORD: test
      MYSQL_DATABASE: wp
  phpmyadmin:
    image: phpmyadmin/phpmyadmin
    container_name: phpmyadmin
    depends_on:
      - db
    ports:
      - 8001:80
    environment:
      MYSQL_ROOT_PASSOWRD: test
  app:
    container_name: wordpress
    build:
      context: ./docker/wordpress/
      dockerfile: wordpress.Dockerfile
    depends_on:
      - db
    links:
      - db:mysql
    ports:
      - 80:80
    restart: always
    volumes:
      - ./wordpress:/var/www/html
    environment:
      WORDPRESS_DB_NAME: wp
      WORDPRESS_DB_USER: root
      WORDPRESS_DB_PASSWORD: test
      WORDPRESS_DEBUG: 1
      XDEBUG_CONFIG: remote_host=host.docker.internalExample configuration file .vscode/launch.json:
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Listen for XDebug",
      "type": "php",
      "request": "launch",
      "port": 9000,
      "pathMappings": {
        "/var/www/html": "${workspaceFolder}"
      },
    }
  ]
}