This image is a development environment for Magento 2 projects. You may either set up a new Magento 2 installation with the provided install script or use the image with your existing Magento project. Apart from the software neccessary to run Magento 2 it includes some useful tools we use a lot in our daily development. These are:
- vim most important
- git
- wget
- curl
- rsync
- ssh
- mysql-client
- zip
- ssmtp needed by mailhog for local mail delivery
- colordiff
- cron used to run Magento cron
This image is meant to be used with docker-compose. The following files are needed to start the image:
You may adjust the docker-compose file to your needs.
If you want to install a fresh Magento installation, execute the install
binary
docker-compose up -d
docker exec -ti {webContainerId} install
To install Sample Data you need to set the env var MAGENTO_INSTALL_SAMPLE_DATA
.
If unset, sample data will not be installed with the install script.
First you have to map your Magento project directory in your docker-compose.yml.
Assuming your project is available in ./web
add volumes as follows:
web:
volumes:
- ./web:/var/www/html
After the change start your containers:
docker-compose up -d
docker exec -ti {webContainerId} init-project
Your project will be set up:
- permissions are being adjusted,
- the env.php is being generated,
- including redis config, if enabled,
- the base url for the default store is being adjusted to what you set in env
You only need to import the database, and you're good to go!
All settings are commented in the example env file.
The following utilities are intended to make your life easier:
install
is the install script to install Magento, either with sample data, or without, see aboveenable-redis
changes the config of Magento so that it uses Redis for cache storage (much better performance, even for developing!)set-permissions
sets permissions for Magento to work properly, according to your user settingsinit-project
inits your project as shown above
xdebug is installed, but not enabled by default. Not everybody needs it but it slows down your app.
Enable it by running:
docker-php-ext-enable xdebug
Then adjust your config.