- Docker
- docker-compose
To run Joinup in containers, we are using the following images:
- php:7.1.24-apache-jessie which is extended with configuration based on the docker for drupal and the fpfis/httpd-php images.
- percona/percona-server:5.6
- tenforce/virtuoso
- selenium/standalone-chrome-debug
- solr:6. This container is extended and comes with the search_api_solr configuration files installed in /opt/docker-solr/configsets/drupal/conf.
To start the containers, you can execute the following command from the project root directory:
$ docker-compose up -d
This will automatically read the docker-compose.yml
file as a source. The -d
command will start the containers in
the background. If you need to debug your build, ommit the -d
parameter and docker-compose will run in the foreground.
You can specify more than one sources in a counter versa priority using the -f parameters. For example
docker-compose -f docker-compose.yml -f docker-compose.local.yml up -d
will start the containers with the variables
from the second source, overriding the first. More of that on
'Override default configuration'.
To stop the containers, you can use the command docker-compose down
from the same directory as the docker-compose.yml.
Using this command however, will only stop the machine and will not destroy the volume that was created with it. To
clean the volume as well, use the -v
parameter as docker-compose down -v
.
Run the following command to install all packages in the vendor folder:
docker-compose exec --user www-data web composer install
From the project root, run:
docker-compose exec --user www-data web ./vendor/bin/run toolkit:build-dev
docker-compose exec --user www-data web ./vendor/bin/run toolkit:install-clean
You can now access the website at http://localhost:8080
or the corresponding endpoint if you have overridden the
settings.
All containers are accessible through the command
docker-compose exec my_container_name "/bin/bash"
Depending on the container (and its base image), it might be that /bin/bash
is not available. In that case, /bin/sh
and sh
are good substitutes.
IMPORTANT: Depending on your configuration, it might be that you have to change the ownership of all the files in order to have a successful installation and to be able to run the tests properly. For a possible solution, please, refer to the section Handling permissions
Some containers, like solr, define volumes that allow the container to directly access files and folders on the host
machine. These volumes are constructed using the top-level volumes
entry in the docker-compose file and inherit all
properties from the containers.
These volumes help retain the data between builds. The since no directory is defined, the local driver will set the
default directory, which is /var/lib/docker/volumes/[volume identifier]
.
This directory is owned by the user that creates it within the container so the directory listing will have to run with root privileges.
Please, note that the volume names, as with the docker services, will be prefixed with the name of the folder that the
project lies within e.g. if you install the project on the myproject
folder, the mysql
volume, will be named
myproject_mysql
.
- When a service is not based on an image, but is built through a Dockerfile, the image is cached in docker-compose
after first build. If changes are made, it can be rebuild using
docker-compose build <container> --no-cache
. - To rebuild all containers on startup use the
--force-recreate
flag as such:docker-compose up --force-recreate
- If a container persists still, use
docker-compose rm <container_id>
to remove it from the docker-compose cache and then recreate the containers.
In your local environment, on the project root, you can create a second docker-compose yml file called
docker-compose.local.yml
. This file is ignored by git. In that file, you can set up services overrides and setup your
own settings on the environment. Below is an example of the docker-compose.override.yml that allows the user that runs
apache to have its UID and GID changed (the group's id changes) and sets up the server to run on port 80.
version: '3.4'
services:
web:
build:
args:
DAEMON_UID: "1000"
DAEMON_GID: "1000"
expose:
- "80"
ports:
- "80:80"
environment:
PORT: "80"
The rest of the service will get the properties from the original composer file.
To run the containers by reading all overrides, use the following command: docker-composer -f docker-compose.yml -f docker-compose.local.yml up
. Please, note, that the last file in the command has bigger priority. More than one
overrides can be provided.
As an example of usage, if you want to have your personal git, composer and ssh settings persist over the web container, you would have to have something like the following override file:
version: '3.4'
services:
web:
volumes:
- .:/var/www/html
- ./build.docker.main.xml:/var/www/html/build.xml
- ~/.gitconfig:/var/www/.gitconfig
- ~/.gitignore:/var/www/.gitignore
- ~/.composer:/var/www/.composer
- ~/.ssh:/var/www/.ssh
Note that in the above snippet the first two lines are also part of the main docker-composer.yml
. This is because
the volumes
entry here will completely override the parent entry and will not merge with it.
For extra configuration, the folder resources/docker/local
is excluded in git and can be used to host local settings.
You can use the volumes section above to add your own preferences to the containers. A good example is provided in the
XDEBUG section below.
For PhpStorm, the procedure to create a debug environment is the same as with local servers with the only difference
that the mappings have to be set.
After you have created the server under File | Settings | Languages & Frameworks | PHP | Servers
. Create a server for
localhost and port 8080, or the port that you with the container to run from. By default, the web container will be
reachable in port 8080. Enable the Use path mappings
option and set the absolute path on the server for your project
root. By default, this is /var/www/html
.
Taking a look at the web container's Dockerfile you will see some default settings for the xdebug. These settings are overridable in the following ways:
- Using the
XDEBUG_CONFIG=
environment variable: This needs to be used every time a php command is run and all overrides must be passed in. e.g.
XDEBUG_CONFIG="remote_autostart=1" php myscript.php
- Using a local override: The php configuration files are in the
/usr/local/etc/php
directory within the web container and can be overridden on demand. The xdebug settings are placed in theusr/local/etc/php/conf.d/95-xdebug.ini
file. Please, note that the95
in the beginning of the file declares the priority within theconf.d
directory. In order to provide overrides for xdebug, you will need to provide a file starting with a number higher than95
. For example, to override theremote_autostart
setting as we did above, you can do by:- Create a file named e.g.
xdebug.local.ini
in theresources/docker/local
directory. - Add
remote_autostart=1
as contents of the file. - Use the following configuration in your docker-compose.local.yml file:
- Create a file named e.g.
version: '3.4'
services:
web:
volumes:
- .:/var/www/html
- ./build.docker.main.xml:/var/www/html/build.xml
- ./resources/docker/local/xdebug.local.ini:/usr/local/etc/php/conf.d/97-xdebug.ini
Our file has a priority of 97
which means that it will be loaded after the 95-xdebug.ini
and thus our settings will
persist over the default file.
After setting up XDEBUG according to your needs, you need to be able to use it when debugging tests. To run the debugger
you need to provide the XDEBUG_CONFIG=
environment variable when running a script. For example, to run a behat test,
run the following command from within the container from the doc root:
XDEBUG_CONFIG= ./vendor/bin/behat -c ./tests/behat.yml
By default, there is no need to pass any settings to the XDEBUG_CONFIG environment variable as all settings are drawn from the xdebug ini files.
The production databases are stored on a private server. In order to get access, ask your friendly project manager for
the paths and credentials. Store them in the build.properties.local
file in the following properties:
exports.s3.key
exports.s3.secret
Download both the SPARQL and SQL database dumps using the following command:
$ docker-compose exec --user www-data web php -d memory_limit=-1 ./vendor/bin/run dev:download-databases
By default, the downloaded databases are stored under the tmp
folder which is
located in the project root. The Virtuoso dumps are stored under the
sub-directory virtuoso
and the MySQL dump is located under the tmp
folder,
mysql.sql
.
To start the machines with the databases restored, first make sure your docker containers are down:
$ docker-compose down
Then start them using the alternative docker-compose file with support for database dumps:
$ docker-compose -f docker-compose.yml -f docker-compose.db.yml up -d
The docker-compose.database.yml
file contains overrides for restoring the databases according to the image
requirements. What it does, is that it maps the dump.sql (the mysql dump) within the startup directory of the mysql
image, and the virtuoso dumps within the startup directory of the virtuoso image.
Note: As you can see in docker-compose.db.yml
, the dumps need to be placed in a specific folder in the container.
You can alter the configuration using your override to draw the dump from anywhere in the host, but the container target
must remain the same. The download of the database is not automatic. You need to download and place them in the
specific directories manually or by using the dev:download-databases
runner command. In any case, the dumps must be
placed as described in the volumes entry in docker-compose.prod_db.yml
.
After the images have been built and the databases have been restored, run the following command to execute the updates:
$ docker-compose exec --user www-data web ./vendor/bin/run toolkit:run-deploy --sequence-file=runner/deploy.yml --sequence-key=default
Finally, in order to run a full re-index of the site, run the command:
$ docker-compose exec --user www-data web ./vendor/bin/run solr:reindex
IMPORTANT: All images start normally and the web server is available almost immediately. However, mysql container will not start until the backup is restored so for the first few minutes, depending on the size of the database dump, the web server will receive connection denials. Please, wait until the mysql import is finishes before accessing the site.
The web container is having the apache service configured to run as user www-data and group www-data. By default, both the UID and GID of this user/group is 82. Docker does not offer a solution for mimicking a user from the host to the container so it might be a bit annoying when testing live while developing.
As a solution the Dockerfile is offering a way to change the UID and GID of the www-data user while the original docker container (fpfis/httpd-php-dev) is offering a way to override the user and group itself. While a new user is not created, if, for example your host user, owner of the files, is having the UID 1000 and its group GID is also 1000, you can override these settings and allow all files to be owned by you. Like this, ownership and permission issues related to the containers should not occur. The way to do this is described above in the section 'Override default configuration'.
Mac users have to define the volumes in a different way than linux. For the default docker-compose profile of Joinup,
there is also a docker-compose.mac.yml file provided in the resources/docker
directory.
Mac users should start the containers by running
docker-compose -f docker-compose.yml -f resources/docker/docker-compose.mac.yml up -d
in order to have the volumes set up correctly.