Skip to content

Configuration files for a Docker container running plain-vanilla Magento Open Source 2.4

License

Notifications You must be signed in to change notification settings

denal05/docker-compose-plain-vanilla-magento-2.4

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

docker-compose-plain-vanilla-magento-2.4

These are configuration files for a Docker environment with several containers that represent a system running a plain-vanilla Magento Open Source 2.4 excluding the Magento root directory.

Note that the following three directories and one file are assumed to be present in your local machine, because they are mapped to the Docker containers:

  /var/www/
  /etc/apache2/ssl/
  ~/.ssh/
  /etc/hosts

Once you download this repository on your local computer, you can start the Docker containers by running:

docker compose up -d --build

where -d means daemon, i.e., start Docker compose in the background, and build means read the Docker-compose.yaml file and build the containers from scratch.

To shut it down:

docker compose down

To check running Docker containers:

docker ps

To troubleshoot, check the Docker container logs:

docker logs m2.4

or, simply start Docker compose in the foreground by omitting the -d flag in order to see all error messages immediately:

docker compose up --build

Prerequisites:

  1. Add information to your /ets/hosts file
  2. Generate a self-signed SSL certificate or use the Let's Encrypt certbot
  3. Create the local directory /var/www/m2.4/pub/

After doing the prerequisites, such as creating the directory /var/www/m2.4/, start the Docker containers, get inside the m2.4 Docker container, run the composer command to fetch the Magento composer project, and then run the command to install Magento via CLI. See the following section #installing-magento-in-your-local-docker-container

Important note: These Docker config files have been made to work out-of-the-box for Docker on Linux. It requires some changes for it to run on Macintosh. The main difference is that on Linux you can access the Docker app container's website on your browser by typing https://m2.4.local in the address bar (i.e. it's based on a local DNS entry), whereas on Mac you have to use https://localhost:8010 or whichever port you configure (i.e. the domain name is always localhost and it's based on the port number). This is because you cannot access Docker container IP addresses directly on the Macintosh host; you have to use localhost with port forwarding as defined in docker-compose.yml.

Known Issues

On restarting the Docker container, Magento can't find any products, and needs reindexing. Simply manually run:

bin/magento indexer:reindex

or set it up in a cron job automatically.

Note to self: Try setting up automatic reindexing upon container restart using entrypoint.sh

Installing Magento in your local Docker container

Manually add the following lines in your /ets/hosts file:

# docker-compose-plain-vanilla-magento-2.4
172.101.0.10    m2.4.local
172.101.0.20    mysql8.local
172.101.0.30    mysql56.local
172.101.0.40    mariadb10.local
172.101.0.50    elasticsearch7.local
172.101.0.60    opensearch11.local
172.101.0.70    redis6.local
172.101.0.80    mailcatcher.local

Create a database and its user:

$ cd ~/projects/docker-compose-plain-vanilla-magento-2.4 
$ docker compose up -d --build  
$ docker exec -it m2.4 bash
# mysql -h mysql8.local -uroot -proot
> create database m24_db;
> create user 'm24_user'@'%' identified by 'magento';
> grant all privileges on m24_db.* to 'm24_user'@'%';
> flush privileges;
> exit;

Optionally, import a database backup if you have one from an existing Magento project:

# mysql -h mysql8.local -uroot -proot
> use m24_db;
> source m24_db.sql;
  OR
# mysql -uroot -proot m24_db < /var/www/m2.4/backups/m24_.sql

Now, let's switch to the Magento root directory:

$ docker exec -it m2.4 bash
# cd /var/www/m2.4/

Obtain credentials to access repo.magento.com.
Follow this tutorial:
https://experienceleague.adobe.com/docs/commerce-operations/installation-guide/prerequisites/authentication-keys.html

Copy the auth.json file with your credentials to access repo.magento.com to the Docker container:

$ cp ~/.composer/auth.json /var/www/m2.4
$ docker exec -it m2.4 bash
# cd /var/www/m2.4
# mv /var/www/m2.4/auth.json /root/.config/composer
# ll /root/.config/composer/
total 28
drwxr-xr-x 1 root root 4096 Dec  7 12:40 ./
drwxr-xr-x 1 root root 4096 Dec  6 17:50 ../
-rw------- 1 root root  301 Dec  7 12:40 auth.json
-rw-r--r-- 1 root root  799 Dec  6 17:50 keys.dev.pub
-rw-r--r-- 1 root root  799 Dec  6 17:50 keys.tags.pub

According to the official Installation Guide - Quick Start On-premises Installation the following commands are required to install Magento Open Source:

# composer create-project --repository-url=https://repo.magento.com/ magento/project-community-edition=2.4.6-p3 /var/www/m2.4/

If for some reason you are getting a timeout error from composer:

The process ... exceeded the timeout of 300 seconds.

then, run the following in the app docker container:

# export COMPOSER_PROCESS_TIMEOUT=3600

and redo the composer create-project command. You might need to erase the /var/www/m2.4 folder before you run composer.

Set file permissions within the docker container (you may need to prepend sudo):
Note: On Linux use the group www-data, but on a Mac use the group _www

# cd /var/www/m2.4/
# find var generated vendor pub/static pub/media app/etc -type f -exec chmod g+w {} +
# find var generated vendor pub/static pub/media app/etc -type d -exec chmod g+ws {} +
# chown -R :www-data .
# chmod -R g+rw .
# chmod u+x bin/magento

Install the Magento Open Source application:

Note: On Linux use --base-url=https://m2.4.local/ \, but on a Mac use --base-url=https://locahost:8010/ \

$ docker exec -it m2.4 bash
# cd /var/www/m2.4
# bin/magento setup:install \
  --base-url=https://m2.4.local/ \
  --db-host=mysql8.local \
  --db-name=m24_db \
  --db-user=m24_user \
  --db-password=magento \
  --admin-firstname=admin \
  --admin-lastname=admin \
  [email protected] \
  --admin-user=admin \
  --admin-password=admin123 \
  --language=en_US \
  --currency=USD \
  --timezone=America/Chicago \
  --use-rewrites=1 \
  --search-engine=elasticsearch7 \
  --elasticsearch-host=elasticsearch7.local \
  --elasticsearch-port=9200 \
  --elasticsearch-index-prefix=magento2 \
  --elasticsearch-timeout=15

Optionally, install the official Magento sample products for a demo store:

$ docker exec -it m2.4 bash
# cd /var/www/m2.4
# bin/magento sampledata:deploy
# bin/magento setup:upgrade

Optionally, change the base_url in the core_config_data table if importing an existing database backup, and don't forget the trailing slash in the URL:

Note: On Linux use set value="https://m2.4.local/", but on a Mac use set value="https://localhost:8010/"

$ docker exec -it m2.4 bash
# mysql -h mysql8.local -uroot -proot
> use magento;
> select * from core_config_data where path like "%base_url%";
> update core_config_data set value="https://m2.4.local/" where path like "%base_url%";

Optionally, create a database backup:

$ docker exec -it m2.4 bash
# mysqldump -h mysql8.local -uroot -proot --databases magento | gzip -9 > /var/www/m2.4/backups/magento_db_2023-11-13T14-50CET.sql.gz

Important Notes

Notes on Composer

If running the following command

$ which composer

returns the following output

/usr/bin/composer

then please remove the composer via apt

$ sudo apt remove composer

and install it per the instructions on https://getcomposer.org/download/ which uses the following command to do so:

php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === 'e21205b207c3ff031906575712edab6f13eb0b361f2085f1f1237b7126d785e826a450292b6cfd1d64d92e6563bbde02') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
sudo mv composer.phar /usr/local/bin/composer

Now, when you run

$ which composer

the result should be:

/usr/local/bin/composer

Notes on PHP

The following is a useful tutorial for having multiple PHP versions on your Ubuntu 22.04: https://techvblogs.com/blog/install-multiple-php-versions-on-ubuntu-22-04

sudo apt update
sudo apt upgrade 
sudo apt install software-properties-common
sudo add-apt-repository ppa:ondrej/php
sudo apt update
sudo apt install php7.4 php7.4-fpm

Add all required PHP extensions listed on https://experienceleague.adobe.com/docs/commerce-operations/installation-guide/system-requirements.html

sudo apt install php7.4-xdebug php7.4-bcmath php7.4-ctype php7.4-curl php7.4-xml php7.4-common php7.4-gd php7.4-intl php7.4-json php7.4-xml php7.4-mbstring openssl php7.4-mysql php7.4-soap php7.4-sockets php-sodium php7.4-xsl php7.4-zip
sudo update-alternatives --config php

Select the desired version, e.g., 7.4 and check:

$ php -v

It should return:

PHP 7.4.33 (cli) (built: Sep  2 2023 08:03:46) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
    with Zend OPcache v7.4.33, Copyright (c), by Zend Technologies
    with Xdebug v3.1.6, Copyright (c) 2002-2022, by Derick Rethans

After you run 'docker compose up -d --build' and check http://m2.4.local you will most likely get a 500 Internal Server Error. If you do, first log into the app container:

docker exec -it m2.4 bash

and inspect the log file

vim /var/log/apache2/m2.4_error.log

If you see the following error:

PHP Fatal error:  Uncaught Error: Call to undefined function xdebug_disable() in /var/www/m2.4/vendor/magento/magento2-functional-testing-framework/src/Magento/FunctionalTestingFramework/_bootstrap.php:73

Stack Overflow has an answer here: https://magento.stackexchange.com/questions/327971/uncaught-error-call-to-undefined-function-xdebug-disable and recommends the following:

Change
vendor/magento/magento2-functional-testing-framework/src/Magento/FunctionalTestingFramework/_bootstrap.php
From :-
    if (!(bool)$debugMode && extension_loaded('xdebug')) {
        xdebug_disable();
    }
To :-
    if (!(bool)$debugMode && extension_loaded('xdebug')) {
        if (function_exists('xdebug_disable')) {
            xdebug_disable();
        }
    }

and visit https://m2.4.local on Linux or https://localhost:8010 on a Mac one more time.

According to the devdocs "Quick start on-premises installation" https://experienceleague.adobe.com/docs/commerce-operations/installation-guide/composer.html?lang=en
if you get an error that it cannot delete files in the generated/ folder, remember to run the following:

$ cd /var/www/m2.4/
$ sudo find var generated vendor pub/static pub/media app/etc -type f -exec chmod u+w {} +
$ sudo find var generated vendor pub/static pub/media app/etc -type d -exec chmod u+w {} +
$ sudo chmod u+x bin/magento

Also, run:

$ cd /var/www/m2.4/
$ sudo chown -R $USER:www-data .
$ sudo chmod -R g+rw .

Notes on Apache

You must manually create a self-signed SSL certificate for Apache in a local environment, or use Let's Encrypt - to generate a valid 3-month SSL certificate for a public website.

Follow this tutorial to create an SSL certificate for your Magento web server:
https://www.digitalocean.com/community/tutorials/how-to-create-a-ssl-certificate-on-apache-for-ubuntu-14-04

$ sudo mkdir /etc/apache2/ssl
$ sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/apache2/ssl/apache.key -out /etc/apache2/ssl/apache.crt

The ubuntu20.04-apache2.4-mysql8.0.30-php7.4.30-m2.4/m2.4.conf file is already configured for SSL, and the ubuntu20.04-apache2.4-mysql8.0.30-php7.4.30-m2.4/entrypoint.sh file already loads the ssl Apache module.

Notes on database errors

After refactoring 'm2.4' throughout its Docker directory and its magento root directory /var/www/m2.4 and upon running

# bin/magento setup:upgrade

I got the following error:

...
SQLSTATE[HY000]: General error: 1419 You do not have the SUPER privilege and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable), query was: CREATE TRIGGER trg_catalog_category_product_after_insert AFTER INSERT ON catalog_category_product FOR EACH ROW
BEGIN
INSERT IGNORE INTO `catalogrule_product_cl` (`entity_id`) VALUES (NEW.`product_id`);
END

The fix was to log in to MySQL as root and run the following command:

> set global log_bin_trust_function_creators=1;

Thanks to https://magento.stackexchange.com/a/144715

Notes on Xdebug

You can follow these videos from Mark Shust to set up Xdebug in PhpStorm and Google Chrome:
Install the Xdebug helper browser plugin for Chrome & PhpStorm
Configure PhpStorm for Xdebug connections
Trigger an Xdebug breakpoint in PhpStorm
Trigger an Xdebug breakpoint for CLI commands in PhpStorm

Note: At the moment, Xdebug only works via http, not HTTPS. You have to comment-out

Notes on MailCatcher

Magento admin panel settings to use MailCatcher:

Stores > Config > Advanced > System > Mail Sending Settings

Disable Email Communications:       No
Transport:                          SMTP
Host:                               mailcatcher.local
Port (25):                          1025
Set Return-Path:                    Yes
Username:
Password:
Auth:                               NONE
SSL:                                None

Notes on CLI tools for backup and restore

Copy from one computer to another:

scp [email protected]:/path/on/server/to/backup_magento.tar.gz /path/on/my/local/computer
scp /path/on/my/local/computer [email protected]:/path/on/server/to/backup_magento.tar.gz

Or even better, use rsync to automatically pick up where it left off after losing connection:

rsync -avz -P -e ssh [email protected]:/path/on/server/to/backup/_var_www_html__xclude-git-log__2024-01-22T16-44CET.zip /path/on/my/local/computer
rsync -avz -P -e ssh /path/on/my/local/computer [email protected]:/path/on/server/to/backup/_var_www_html__xclude-git-log__2024-01-22T16-44CET.zip

Archive a directory for backup:

zip -r /path/on/server/to/backup/_var_www_html__xclude-git-log__2024-01-22T16-44CET.zip /var/www/html/ -x *.git* -x *.log

Take a snapshot of the database as a flat SQL file for backup:

mysqldump -h <hostname> -u<username> -p<password> --databases <db_name> | gzip -9 > /path/on/server/to/backup/db_name__2024-01-22T16-55CET.sql.gz

Find out the disk usage of files and directories under a parent directory, filtered by Gigabytes:

du -h /var/www/html | grep [0-9]G > /path/on/server/to/stats/du/du_-h_var_www_html_PIPE_grep_\[0-9\]G__2024-01-22T16-31CET.txt

Find out the general disk space on a computer:

df -h

Notes on running multiple projects

Usually developers need to run multiple Magento projects for their job. Additionally, you might need to run Magento projects at the same time, for example, to compare behavior with and without a certain module, to compare behavior before and after an upgrade of the same project, etc. This is ideally done via Docker, but it requires careful planning. Each time you need to create a new instance of a Magento Docker environment for another project, modify the docker-compose.yaml file to have unique container names, unique ports, and unique network name and subnet IP address mask. Then, manually edit the /etc/hosts file to take into account the new Magento project. My favorite tool for simultaneous comparing and editing files common to multiple projects, such as docker-compose.yaml, is gvimdiff.

Other Tutorials

How to setup Magento on Docker

https://www.mageplaza.com/kb/setup-magento-2-on-docker.html
https://github.com/markshust/docker-magento

How to upgrade Magento

Unofficial:
https://www.mageplaza.com/kb/setup-magento-2-on-docker.html
https://www.codextblog.com/magento-2/upgrade-magento-version-2-3-x-2-4-0/

Official:
https://experienceleague.adobe.com/docs/commerce-operations/upgrade-guide/overview.html?lang=en
https://experienceleague.adobe.com/docs/commerce-operations/upgrade-guide/implementation/perform-upgrade.html

About

Configuration files for a Docker container running plain-vanilla Magento Open Source 2.4

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published