• Stars
    star
    278
  • Rank 148,454 (Top 3 %)
  • Language
    Shell
  • License
    BSD 3-Clause "New...
  • Created over 9 years ago
  • Updated about 6 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A dockerized Magento Community Edition 1.9.x

Dockerized - Magento Community Edition 1.9.x

A dockerized version of "Magento Community Edition 1.9.x"

Requirements

If you are on Linux you should install

If you are running on Mac OS or Windows you can install the Docker Toolbox which contains docker, docker-compose and docker-machine.

Preparations

The web-server will be bound to your local ports 80 and 443. In order to access the shop you must add a hosts file entry for dockerized-magento.local.

For Linux Users

In order to access the shop you must add the domain name "dockerized-magento.local" to your hosts file (/etc/hosts). If you are using docker natively you can use this command:

sudo su
echo "127.0.0.1    dockerized-magento.local" >> /etc/hosts

For Mac Users

If you are using docker-machine you need to use the IP address of your virtual machine running docker:

docker-machine ls
docker-machine ip <name-of-your-docker-machine>
echo "192.168.99.100    dockerized-magento.local" >> /etc/hosts

docker-machine performance

For faster sync between your host system and the docker machine image I recommend that you activate NFS support for virtualbox: github.com/adlogix/docker-machine-nfs

docker-machine create --driver virtualbox nfsbox
docker-machine-nfs nfsbox

And to fix issues with filesystem permissions you can modify your NFS exports configuration:

  1. open /etc/exports and replace -mapall=$uid:$gid with -maproot=0
  2. sudo nfsd restart

Thanks to René Penner for figuring that out.

For Windows Users

I suppose it will work on Windows, but I have not tested it. And I suspect that the performance will not be great due to the slow file-sharing protocol between the Windows hosts and the VirtualBox VM.

Installation

  1. Make sure you have docker and docker-compose on your system
  2. Clone the repository
  3. Start the projects using ./magento start or docker-compose up
git clone https://github.com/andreaskoch/dockerized-magento.git && cd dockerized-magento
./magento start

During the first start of the project docker-compose will

  1. first build all docker-images referenced in the docker-compose.yml
  2. then start the containers
  3. and trigger the installer which will

Once the installation is finished the installer will print the URL and the credentials for the backend to the installer log:

...
installer_1      | phpMyAdmin: http://dockerized-magento.local:8080
installer_1      |  - Username: root
installer_1      |  - Password: pw
installer_1      |
installer_1      | Backend: http://dockerized-magento.local/admin
installer_1      |  - Username: admin
installer_1      |  - Password: password123
installer_1      |
installer_1      | Frontend: http://dockerized-magento.local/

Animation: Installation and first project start

Note: The build process and the installation process will take a while if you start the project for the first time. After that, starting and stoping the project will be a matter of seconds.

Usage

You can control the project using the built-in magento-script which is basically just a wrapper for docker and docker-compose that offers some convenience features:

./magento <action>

Available Actons

  • start: Starts the docker containers (and triggers the installation if magento is not yet installed)
  • stop: Stops all docker containers
  • restart: Restarts all docker containers and flushes the cache
  • status: Prints the status of all docker containers
  • stats: Displays live resource usage statistics of all containers
  • magerun: Executes magerun in the magento root directory
  • composer: Executes composer in the magento root directory
  • enter: Enters the bash of a given container type (e.g. php, mysql, ...)
  • destroy: Stops all containers and removes all data

Note: The magento-script is just a small wrapper around docker-compose. You can just use docker-compose directly.

Components

Overview

The dockerized Magento project consists of the following components:

The component-diagram should give you a general idea* how all components of the "dockerized Magento" project are connected:

Dockerized Magento: Component Diagram

* The diagram is just an attempt to visualize the dependencies between the different components. You can get the complete picture by studying the docker-compose file: docker-compose.yml

Even though the setup might seem complex, the usage is thanks to docker really easy.

If you are interested in a guide on how to dockerize a Magento shop yourself you can have a look at a blog-post of mine: Dockerizing Magento on AndyK Docs

Custom Configuration

All parameters of the Magento installation are defined via environment variables that are set in the docker-compose.yml file - if you want to tailor the Magento Shop installation to your needs you can do so by modifying the environment variables before you start the project.

If you have started the shop before you must repeat the installation process in order to apply changes:

  1. Modify the parameters in the docker-compose.yml
  2. Shutdown the containers and remove all data (./magento destroy)
  3. Start the containers again (./magento start)

Changing the domain name

I set the default domain name to dockerized-magento.local. To change the domain name replace dockerized-magento.local with your-domain.tld in the docker-compose.yml file:

installer:
  environment:
    DOMAIN: dockerized-magento.local

Using a different SSL certificate

By default I chose a dummy certificate (config/ssl/cert.pem). If you want to use a different certificate you can just override the key and cert with your own certificates.

Adapt Magento Installation Parameters

If you want to install Magento using your own admin-user or change the password, email-adreess or name you can change the environment variable of the installer that begin with ADMIN_:

  • ADMIN_USERNAME: The username of the admin user
  • ADMIN_FIRSTNAME: The first name of the admin user
  • ADMIN_LASTNAME: The last name of the admin user
  • ADMIN_PASSWORD: The password for the admin user
  • ADMIN_EMAIL: The email address of the admin user (Note: Make sure it has a valid syntax. Otherwise Magento will not install.)
  • ADMIN_FRONTNAME: The name of the backend route (e.g. http://dockerized-magento.local/admin)
installer:
  build: docker-images/installer
  environment:
		ADMIN_USERNAME: admin
		ADMIN_FIRSTNAME: Admin
		ADMIN_LASTNAME: Inistrator
		ADMIN_PASSWORD: password123
		ADMIN_FRONTNAME: admin
		ADMIN_EMAIL: [email protected]

Change the MySQL Root User Password

I chose a very weak passwords for the MySQL root-user. You can change it by modifying the respective environment variables for the mysql-container ... and installer because otherwise the installation will fail:

installer:
  environment:
    MYSQL_PASSWORD: <your-mysql-root-user-password>
mysql:
  environment:
    MYSQL_ROOT_PASSWORD: <your-mysql-root-user-password>

More Repositories

1

allmark

A cross-platform markdown web server
Go
314
star
2

dcsg

dcsg is a command-line utility for Linux that generates systemd services for Docker Compose projects
Go
185
star
3

go-fswatch

fswatch is a go library for monitoring filesystem changes that does not depend on inotify
Go
59
star
4

gargantua

The fast website crawler
Go
34
star
5

togglcsv

Toggl⥃CSV is a command line utility for Windows, Mac OS and Linux that imports or exports time reports to and from a Toggl account via CSV files
Go
17
star
6

go-autobuild

autobuild your go projects
Go
8
star
7

MagentoTutorial

Magento Development Tutorial
8
star
8

ga-spam-control

Command-line utility for blocking referrer spam from your Google Analytics accounts
Go
6
star
9

dotman

A tool to bootstrap your system configuration files
Go
5
star
10

go-fswatcher

fswatcher is a cross platform filesystem watcher which allows you to execute a custom command every time a file or folder changes
Go
4
star
11

Hostfile-Manager

The Hostfile Manager is a free and simple .NET 4.0 based WPF application that allows you to view, edit and manage your local machines' hosts file.
C#
4
star
12

soapui-project-normalization

A cross-platform SoapUI project file normalization utility written in Go
Go
3
star
13

togglapi

A go wrapper for the Toggl API
Go
3
star
14

SignalKo-SystemMonitor

A web-based system monitor that collects server performance data, distributes it via SignalR and displays the data using KnockoutJS.
JavaScript
3
star
15

reverse-proxy

A Nginx based reverse proxy or one or more sites on one ip address as a docker image
Shell
3
star
16

docker-prometheus-monitoring

Monitoring for Docker hosts using Prometheus
2
star
17

tekpub-catcher

A command-line tool that downloads your Tekpub videos and gives them sensible names
Go
2
star
18

docker-registry-with-authentication

A private docker registry that used a NGINX reverse proxy to add basic authentication
Shell
2
star
19

postdeploy

postdeploy is a cross-platform deployment-hook listener written in go
Go
2
star
20

alexa-ops

The 24/7 endpoint for your "Amazon Echo" based DevOPS skills
1
star
21

dee-cli

Cross-platform command-line utility for DNS updates via DNSimple
Go
1
star
22

dee-ns

A go-library for reading and updating DNS records
Go
1
star
23

NuDeploy

Tool for Nuget-based Deployments
C#
1
star
24

pandoc

A docker image for running the latest version of pandoc built from source
1
star