Skip to content

gigatec/docker-magento2

 
 

Repository files navigation

Docker image for Magento 2

Docker build

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

Requirements

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.

Usage

Install Magento 2

If you want to install a fresh Magento installation, execute the install binary

docker-compose up -d
docker exec -ti {webContainerId} install

Sample Data

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.

Use with existing Magento 2 project

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!

Settings

All settings are commented in the example env file.

Utilities

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 above
  • enable-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 settings
  • init-project inits your project as shown above

Additional configuration

xdebug

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.

About

Docker image for Magento 2

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%