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:
- Add information to your
/ets/hosts
file - Generate a self-signed SSL certificate or use the Let's Encrypt certbot
- 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.
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
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
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
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 .
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.
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
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
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
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
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.
https://www.mageplaza.com/kb/setup-magento-2-on-docker.html
https://github.com/markshust/docker-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