Cloud Docker package
The magento/magento-cloud-docker package provides functionality and Docker images to deploy Adobe Commerce to a local Cloud environment. These release notes describe the latest improvements to this package, which is a component of Cloud Tools Suite for Commerce.
The magento/magento-cloud-docker package uses the following version sequence: <major>.<minor>.<patch>
The release notes include:
-
New features -
Fixes and improvements
v1.4.8 latest
Release date: May 06, 2026
-
Updated service tests—Updated tests for MariaDB, RabbitMQ, ActiveMQ, Opensearch and Valkey. -
Valkey—Added Valkey 8.1 support. -
Opensearch image—Added Opensearch 2.19 and 3.5. -
ActiveMQ—Added ActiveMQ 2.51 support. -
MariaDB—Added MariaDB 11.8 and 12.2 support. -
MailHog—Fixed the MailHog image.
v1.4.7
Release date: March 05, 2026
-
PHP 8.5—Added support for PHP 8.5. -
Addedphp-cliandphp-fpm8.5 images—Added new Cloud Docker images (CLI and FPM) with PHP 8.5 support. -
Added PHP 8.5 and Opensearch 3.0 docker image generation commands-Resolved Docker network isolation (including ARM64), fixed integration tests and added PHP 8.5 and OpenSearch 3.0 support for Docker image generation commands.
v1.4.6
Release date: November 13, 2025
-
Symfony package-Added support for the latest Symfony YAML packages.
v1.4.5
Release date: October 08, 2025
-
ActiveMQ—Added ActiveMQ support in cloud-docker with functional tests.
v1.4.4
Release date: August 07, 2025
-
PHP 8.4—Added PHP 8.4 tests. -
FTP extension-Added fix for FTP extension. -
Opensearch3 image—Added support of Opensearch3. -
Opensearch3 tests—Added PHP 8.4 tests for Opensearch3. -
Valkey—Added support for Valkey.
v1.4.3
Release date: June 03, 2025
-
Improved compatibility with 2.4.8-Updated 3rd-party libraries for better compatibility with 2.4.8
v1.4.2
Release date: April 7, 2025
-
PHP 8.4—Addedphp-cli8.4 andphp-fpm8.4 images.
v1.4.1
Release date: February 6, 2025
-
PHP 8.4—Added support for PHP 8.4.
v1.4.0
Release date: October 7, 2024
-
Refactored code—Removed support of old PHP versions (7.4, 7.3, 7.2) and related libraries and images.
v1.3.7
Release date: April 8, 2024
-
PHP — Added support for PHP 8.3 and PHP 8.3 images. -
Nginx — Added image nginx v. 1.24. -
Opensearch - Added image OpenSearch v. 2.12, 1.3. -
Composer - Updated Composer version to 2.2.23.
v1.3.6
Release date: July 31, 2023
-
Added new service version—OpenSearch 2.5. -
Enable Composer cache—Now you can extend the Docker configuration to enable Composer clear cache when starting the Docker container. See Extend the Docker configuration in the Cloud Docker for Commerce guide.
v1.3.5
Release date: March 10, 2023
-
ionCube—Added the ionCube extension for the PHP 8.1 image. -
Added new service versions—OpenSearch 2.3 and 2.4, PHP 8.2, Varnish 7.1.1. -
Enhanced support for PHP 8.2—Fixed compatibility issues with certain PHP 8.2.x versions to support Commerce 2.4.6. -
Composer issue—Fixed issues that occurred after updating the Composer version within the Docker containers.
v1.3.4
Release date: October 27, 2022
-
Added new Varnish images—Added images for Varnish 6.5, 7.0, and 7.1.
v1.3.3
Release date: September 13, 2022
-
Apple M1 (ARM64) support—Added changes to Docker images to enable support for Apple M1 (ARM64) architecture. -
Mailhog—Fixed an issue where the Mailhog service did not catch emails while in developer mode. -
init-docker.sh—Fixed the service versions validator in theinit-docker.shscript.
v1.3.2
Release date: March 31, 2022
-
Added Elasticsearch 7.10 image
v1.3.1
Release date: March 10, 2022
-
Support PHP 8.1—Added support for PHP 8.1. -
OpenSearch—Added images of OpenSearch versions 1.1 and 1.2. -
Composer 2.1—Set composer 2.1.x by default in PHP 8.x images. -
PHP images improvements—- Added PHP 8.1 images
- Upgraded xDebug version 3.1.2
- Upgraded xmlrpc 1.0.0RC3
-
Elasticsearch & OpenSearch improvements—Improvements in Elasticsearch and OpenSearch Dockerfiles; removed the Elasticsearch 5.2 image. -
Sodium extension—Enabled thesodiumextension by default in all PHP images. -
Composer cache volume—Fixed path for Composer cache volume to have cached Composer packages. -
Memory limitation in nginx—Fixed limitation of memory in NGINX image.
v1.3.0
Release date: October 25, 2021
-
Improve Developer mode workflow—Previously, you needed to specify the mode in the build and deploy steps. Now, the--modeoption in thebuildstep determines the mode in the laterdeploystep. Setting the mode after the deployment is no longer required. See Developer mode. -
Improvements for read-only filesystem—- Fix issue starting a PHP container for mail configuration.
- Can use environment variables in INI files.
- Ensure PHP entry points do not need write permission.
-
Update Node—Update the bundled Node version; when installing Node in PHP-CLI images, it now uses the current LTS version. -
Update Symfony—Updated the Symfony config dependencies to be compatible with Adobe Commerce 2.4.4.
v1.2.4
Release date: July 29, 2021
-
NewZookeepercontainer—Added a Zookeeper container to manage lock provider configuration for projects that are not deployed to Adobe Commerce on Cloud infrastructure. -
Added support for Composer 2.0.—Added Composer version 2.0 to the Composer configuration file to support upgrades from Composer 1.0 which is approaching end-of-life.
v1.2.3
Release date: June 14, 2021
-
Added PHP 8.0—Updated PHP to version 8.0, allowing you take advantage of all the new features and optimizations PHP 8.0 includes. -
Updated to Varnish 6.6 and Elasticsearch 7.11.2—The following links provide release information on Varnish Cache 6.6 and Elasticsearch 7.11.2. -
Addedioncubeextension for PHP 7.4 image—Theioncubeextension has been re-added to the PHP 7.4 image after having been initially excluded from the PHP 7.3 to PHP 7.4 upgrade. Submitted by mattskr. -
Added a file sync option:manual-native—Themanual-nativefile synchronization option provides manual control over synchronization, which provides the best performance for macOS and Windows environments. Read about using themanual-nativeoption in Developer mode and Synchronizing data in a Docker developer environment. -
Removed volume deletions fromupanddowncommands—The--volumeoption was removed from thebin/magento-docker upandbin/magento-docker downcommands, replaced by the newbin/magento-docker initcommand with a data loss warning. This change helps prevent the accidental data loss. Submitted by joeshelton-wagento. -
UpdatedCNvalue for the generated certificate—Removed the hardcodedCNvalue from the Dockerfile. This value created a certificate error (NET::ERR_CERT_INVALID) that caused the--hostoption for theece-docker build:composecommand to be ignored.
v1.2.2
Release date: April 20, 2021
-
Updatedhost.docker.internalto be platform independent—You can now create the same Docker Compose scripts for Ubuntu, Windows, and macOS. Using Xdebug on Ubuntu no longer requires a separate environment variable. Fix submitted by Igor Vitol. -
Updated init-docker.sh—Added themountsobject to theMAGENTO_CLOUD_APPLICATIONenvironment variable. Fix submitted by Chiranjeevi. -
Updated init-docker.sh—Updated theinit-docker.shscript with PHP 7.4 and Cloud Docker 1.2.1 versions. Fix submitted by Adarsh Manickam. -
Sodium enabled by default—Enabled thesodiumPHP extension by default within PHP Docker images. -
custom-registryoption—Added a--custom-registryoption tophp ./vendor/bin/ece-docker build:composecommand for using your own images registry.code language-bash ./vendor/bin/ece-docker build:compose --custom-registry=my-registry.example.com -
Removed old Elasticsearch versions—Removed Elasticsearch versions 1.7 and 2.4 from the Elasticsearch images. -
Auto-generating NGINX certificates—Removed the existing certificates from the NGINX image. The NGINX certificates are now auto-generated with each new deployment for improved security. -
Enabledopcache.validate_timestamps—Enabled theopcache.validate_timestampsPHP setting by default in developer mode. Enabling this setting fixed the issue where changes to the filesystem were not recognized in Docker. -
Fixedbuild:custom:compose—Fixed thebuild:custom:composecommand to throw an error when files cannot be overwritten during the build process. Throwing an error prevents situations wheredocker-compose upcould be using the wrong files. -
Fixed--sync_engine="native"option—Fixed the issue where in production mode (--mode="production"), the--sync_engine="native"option would not create any entries for local folders in thedocker.composer.ymlfile. -
Fixed service version validation errors—Added service versions for RabbitMQ, Elasticsearch, and other services to thetypeproperty in theMAGENTO_CLOUD_RELATIONSHIPvariable. Adding these versions to therelationshipsvariable fixed the validation errors that occurred during the deploy phase.
v1.2.1
Release date: December 21, 2020
-
NGINX command options—Added build command options to change the number of NGINXworker_processesand NGINXworker_connectionsfor TLS and Web services. Theworker_processparameter retains the ability to set the value toauto. Examples:code language-bash ./vendor/bin/ece-docker build:compose --nginx-worker-processes=2 ./vendor/bin/ece-docker build:compose --nginx-worker-connections=2048 -
TLS command option—Added build command option to create a configuration without the TLS service. Example:code language-bash ./vendor/bin/ece-docker build:compose --no-tls -
NGINX memory consumption—Reduced the memory consumed by the NGINX process for TLS and Web services. -
Blackfire—Disabled Blackfire PHP extension by default in the Cloud Docker image. -
PHP-FPM container—Fixed PHP-FPM container health check by changing theWEB_PORTfrom80to8080. -
Invalid volume naming—Fixed an error with invalid volume naming in developer mode. -
NGINX upstream port—Updated the Docker NGINX 1.19 image to use port 8080 to avoid an infinite loop. Fix submitted by Adarsh Manickam.
v1.2.0
Release date: November 9, 2020
-
Container updates—-
PHP-FPM container—Added support for the gnupg PHP extension. Fix submitted by G Arvind from Zilker Technology. -
Database container—Fixed the database container health check by adding the required database password to the health check command. -
Elasticsearch container-
Added support for Elasticsearch 7.9 for compatibility with upcoming Adobe Commerce releases.
-
Elasticsearch plugin configuration—Added support to use the Elasticsearch plugin configuration information from the
services.yamlfile to generate thedocker-compose.yamlfile for a Cloud Docker for Commerce environment. See Elasticsearch plugins. -
Elasticsearch plugin support—Added support for the following Elasticsearch plugins:
analysis-icu,analysis-phonetic,analysis-stempel, andanalysis-nori. Theanalysis-icuandanalysis-phoneticplugins are installed by default. You can add or remove theanalysis-stempelandanalysis-noriplugins as needed.
-
-
CLI container-
Run commands inside Docker PHP containers—Now you can use the Cloud Docker CLI to run commands inside PHP containers in your Docker environment without having to install PHP on the host. For example, the following command builds the configuration:
./bin/magento-docker php 7.3 vendor/bin/ece-docker build:compose. See Cloud Docker CLI. Fix submitted by G Arvind from Zilker Technology. -
Added the OpenSSH-client to PHP CLI containers. Now, you can use ssh-agent forwarding for Composer if the
composer.jsonfile contains private git repositories that require an ssh client to use Composer commands.
-
-
TLS container—Now, the TLS container is based on thehttps://hub.docker.com/r/magento/magento-cloud-docker-nginxDocker image instead of the CentOS image. This change fixes issues that caused errors when sending HTTPS requests between containers in the Cloud Docker environment. -
Test container—Added a test container for application testing, and added the--with-testoption to the Dockerbuild:composecommand to create the container only when testing in the Docker environment. See application testing. -
FPM-XDEBUG container-
Configure Xdebug on Linux—Added the--set-docker-hostoption to theece-docker build:composecommand to configure thehost.docker.internalvalue in the Xdebug container. This option is required to use Xdebug on Linux systems. See Configure Xdebug for Docker. -
Fixed the Xdebug variable configuration for the Docker ENTRYPOINT to resolveuninitialized "with_xdebug" variableerrors in the logs. Fix submitted by Florent Olivaud
-
-
-
Docker configuration changes-
MailHog configuration—Now you can use the following
ece-docker build:composecommand options to disable MailHog and specify ports:--no-mailhog,--mailhog-http-port, and--mailhog-smtp-port. See Set up email. -
For Cloud Docker for Commerce 1.2.0 and later, Adobe now provides Docker images for each patch version, and the Docker configuration generator creates the Docker configuration with a specified patch version instead of using the latest. Previously, the Docker configuration generator built the configuration using the latest patch version which could break Cloud Docker for Commerce environments built using an earlier version.
-
Specify custom images and versions in custom Cloud Docker configuration—Updated the
build:custom:composecommand with options to specify custom images and versions when generating a custom Docker compose configuration file (docker-compose.yaml). See Build a custom Docker Compose configuration. -
Updated the Docker host configuration to expose port 443 to enable access to Adobe Commerce (
https://magento2.docker) from all CLI containers. You can change the default port by adding the--tls-portoption when you generate the Docker configuration file.
-
-
Fixed an issue that caused the Cloud Docker for Commerce build to fail if theapp/etc/env.phpfile exists. -
Updated the build configuration to replace named volumes with regular volumes to prevent issues when deploying Cloud Docker for Commerce on Linux or Windows Subsystem for Linux (WSL2). -
Updated the Cloud Docker for Commerce functional tests to support Composer 2.0.
v1.1.2
Release date: September 9, 2020
-
Added support for Elasticsearch 7.7
v1.1.1
Release date: August 5, 2020
-
Updated email configuration—Updated the default Cloud Docker for Commerce configuration to support the MailHog service instead of using SendMail. See Set up email. -
Restored the PS library to the Cloud Docker environment configuration to fixps: command not founderrors. -
Updated the default Cloud Docker for Commerce configuration to remove automatic mounting of the database entrypoint and MariaDB volumes to fixCannot create container for service dberrors that can occur when starting your Cloud Docker environment.Now, you can configure the Cloud Docker environment to mount the database directories by adding the following options to the
ece-docker build:composecommand:--with-entry-pointandwith-mariadb-conf. See Service configuration options. -
CLI command updates
./vendor/bin/ece-docker build:compose --db --with-entrypoint./vendor/bin/ece-docker build:compose --db --mariadb-confv1.1.0
Release date: June 25, 2020
-
Added support for the split database performance solution—Now you can configure and deploy a store using the Split database performance solution in the Cloud Docker environment. -
Support for Adobe Commerce and Magento Open Source deployment—Now you can use Cloud Docker for Commerce to deploy a local development environment for projects that are not hosted on Adobe Commerce on cloud infrastructure. -
Blackfire.io support—Added support to use the Blackfire.io extension for automated performance testing. Fix submitted by Adarsh Manickam from Zilker Technology -
Container updates-
Varnish—Now Varnish is the default cache when you deploy Adobe Commerce in a Cloud Docker environment using a supported version of the Cloud application template. See Varnish container.
-
Added the
--no-varnishoption to skip Varnish service installation when you generate the Cloud Docker configuration file. -
Database-
Added the support for the MySQL database. Now, you can configure the Cloud Docker environment with either MariaDB or MySQL. See Service configuration options.
-
Added the ability to set the increment and offset settings for database replication when you generate the Docker compose file. See Service containers.
-
-
PHP-FPM-
Added support for PHP 7.4. Fix submitted by Mohanela Murugan from Zilker Technology
-
Added ability to copy a
php.inifile in the root project directory to the Cloud Docker environment and apply custom PHP settings to the PHP-FPM and CLI containers. See Customize PHP settings. Fix submitted by Mathew Beane from Zilker Technology. -
Added a container health check. Fix submitted by Visanth Sampath from Zilker Technology.
-
-
Node.js—Updated the default Node.js version from version 8 to version 10 to improve security. Node.js version 8 is deprecated and no longer updated with bug fixes or security patches. Fix submitted by Mohan Elamurugan from Zilker Technology. -
Elasticsearch-
Added support for Elasticsearch 6.8, 7.2, 7.5, and 7.6.
-
Added the ability to customize the Elasticsearch container configuration when you generate the Docker compose configuration file.
-
Added the
--no-esoption to the service configuration options for generating the Docker Compose configuration file. Use this option to skip the Elasticsearch container installation and use MySQL search instead. This option is supported only for Adobe Commerce versions 2.3.5 and earlier.
-
-
FPM-XDEBUG container—Added a service configuration option to install and configure Xdebug for debugging PHP in your Cloud Docker environment. See Configure Xdebug.
-
-
Docker configuration changes-
Added health checks for the PHP-FPM, Redis, Elasticsearch, and MySQL Docker service containers.
-
Changed the default file synchronization mode to
nativein Developer mode. -
Added version information to the generic Docker service container image when generating the
docker-compose.ymlfile. -
Improved ability to handle large responses from the upstream PHP-FPM container by increasing the
fastcgi_buffersvalue for the Nginx server. -
Improved mutagen file synchronization performance by adding a second sync session to synchronize files in the
vendordirectory. This change prevents mutagen from getting stuck during the file synchronization process. Fix submitted by Mathew Beane from Zilker Technology. -
CLI command updates
-
bin/magento-docker flush-redisbin/magento-docker flush-varnish.vendor/bin/ece-docker build:compose --no-varnish.vendor/bin/ece-docker build:compose --es-env-var.vendor/bin/ece-docker build:compose --no-es./vendor/bin/ece-docker build:compose --db <mysql-version-number> --db-image mysql./vendor/bin/ece-docker build:compose --host=<hostname> --port=<port-number>.vendor/bin/ece-docker build:compose --mode developer --sync-engine native --with-xdebug-
Fixed the configuration of mutagen file synchronization to prevent mutagen from creating stale sessions. Fix submitted by Mathew Beane from Zilker Technology. -
Fixed a configuration issue that caused syntax errors in the Docker compose log when starting the PHP-FPM container. Fix submitted by Mathew Beane from Zilker Technology -
Fixed volume conflict errors that sometimes occurred when using multiple Docker environments. Fix submitted by G Arvind from Zilker Technology. -
Fixed an issue that caused theece-docker build:composecommand to fail if the configuration included Blackfire.io. Fix submitted by G Arvind from Zilker Technology. -
Updated the PHP CLI image configuration to prevent out-of-memory errors that occurred when installing multiple packages using Cloud Docker for Commerce. Fix submitted by Mohan Elamurugan from Zilker Technology.* -
Added support for multiple MySQL users in the Cloud Docker environment. In earlier releases, thebuild:composeoperation failed if themagento.app.yamlfile specified multiple database users. Fix submitted by G Arvind from Zilker Technology. -
Removedrsyslogfrom the Cloud Docker for Commerce PHP containers to resolve compatibility issues that caused warning notifications during deployment. Cloud Docker does not use the rsyslog utility.
v1.0.0
Release date: Feb 5, 2020
-
Created a separate package to deliverCloud Docker for Commerce—Moved the source code to deliver Cloud Docker for Commerce from theece-toolsrepository to the newmagento-cloud-dockerrepository to maintain code quality and provide independent releases. The new package is a dependency for ECE-Tools v2002.1.0 and later.When you update ece-tools, you also update the
magento/magento-cloud-dockerpackage to version 1.0.0. If you used Cloud Docker for Commerce with an earlierece-toolsrelease (2002.0.x), review the backward incompatibilities and update your project as scripts, commands, and processes as needed. -
Added versioning to the Docker images—You must now update themagento/magento-cloud-dockerpackage to get the updated images. -
Container updates—-
PHP-FPM container—-
Added Node.js support—Updated the PHP-FPM image to support node, npm, and the grunt-cli capabilities inside the PHP container. -
Added support for ionCube—Updated the default Docker configuration to support ionCube in the local Docker development environment.
-
-
Web container—-
Customize NGINX configuration—Added the capability to mount a customnginx.conffile to the Cloud Docker for Commerce environment. See Web container. -
Auto-generated NGINX certificates—The Docker configuration file now includes the configuration to auto-generate NGINX certificates for the Web container.
-
-
New Selenium container—Added a Selenium container to support Adobe Commerce application testing using the Magento Functional Testing Framework (MFTF). -
RabbitMQ version support—Updated the RabbitMQ container configuration to support RabbitMQ version 3.8. -
Persistent database container—Themagento-db: /var/lib/mysqldatabase volume now persists after you stop and remove the Docker configuration and restores when you restart the Docker configuration. Now, you must manually delete the database volume. See [Database containers]. -
TLS container—-
Updated the container base image to use official image—The Cloud TLS container image is now based on the officialdebian:jessieDocker image.— -
Added support for the [Pound TLS Termination Proxy]—The Pound configuration file adds the following ENV variables to customize the Docker configuration for the TLS container:-
TimeOut—Sets the Time to First Byte (TTFB) timeout value. The default value is 300 seconds. -
RewriteLocation—Determines whether the Pound proxy rewrites the location to the request URL by default. Defaults to0to prevent the rewrite from breaking redirects to outside websites like an external SSO site. Fix submitted by Sorin Sugar
-
-
Increased the timeout value in the TLS container configuration from 15 to 300 seconds. Fix submitted by Mathew Beane from Zilker Technology
-
-
Varnish container—-
Updated the container base image to use official image—The Cloud Varnish container is now based on the officialcentosDocker image. -
Improved default timeout configuration-Added.first_byte_timeoutand.between_bytes_timeoutconfiguration to the Varnish container. Both timeout values default to300s(5 minutes). Fix submitted by Mathew Beane from Zilker Technology -
Skip Varnish during Xdebug sessions—Updated the Varnish container configuration to returnpasson requests received when Xdebug is enabled. In previous releases, you could not use Xdebug if the Docker environment included Varnish. Fix submitted by Mathew Beane from Zilker Technology.
-
-
-
Docker configuration changes—-
Manage mounts and volumes for your project—Added the ability to manage mounts and volumes when launching a Docker environment for local development. See [Sharing project data]. -
Support for network bridge mode—Added support for network bridge mode to enable connections between Docker containers over the local network. -
Cron container disabled by default—To improve performance, the Cron container is no longer configured by default when you build the Docker environment. You can use the--with-cronoption on the Docker build command to add a Cron container to your environment. See Managing cron jobs. -
Stop synchronizing large backup files—Added DB dumps and archive files—ZIP, SQL, GZ, and BZ2—to the exclusion list in thedist/docker-sync.ymlanddist/mutagen.shfiles. Synchronizing large files (>1 GB) can cause a period of inactivity and backup files do not normally require synchronization since you can regenerate them.
-
-
Command changes—-
Renamed the./bin/dockerfile to./bin/magento-dockerto fix an issue that caused some Docker environments to break because the./bin/dockerfile overwrites existing Docker binary files. This is a backward incompatible change that requires updates to your scripts and commands. -
Added a service configuration option to expose the database port to the host—Use the--expose-db-port= [Fix submitted by Adarsh Manickam from Zilker Technology](https://github.com/magento/magento-cloud-docker/pull/101).<PORT>option to expose the database port to the host when building thedocker-compose.ymlfile:bin/ece-docker build:compose --expose-db-port=<PORT> -
New post-deploy command—Previously, the post-deploy hooks defined in the.magento.app.yamlfile ran automatically after you deployed Adobe Commerce to a Cloud Docker container using thecloud-deploycommand. Now, you must issue a separatecloud-post-deploycommand to run the post-deploy hooks after you deploy. See the updated launch instructions for developer and production mode. -
Added the--rmoption to./bin/magento-dockercommands for the build and deploy containers. This removes the container after the task is complete. -
Updates tobuild:composecommand—-
Added the--sync-engine="native"option to thedocker-buildcommand to disable file synchronization when you generate the Docker Compose configuration file in developer mode. Use this option when developing on Linux systems, which do not require file synchronization for local Docker development. See Synchronizing data in the Docker environment.
-
-
Changed the default file synchronization setting fromdocker-synctonative. Fix submitted by Mathew Beane from Zilker Technology.
-
-
Validation improvements—-
Added validation to the deployment process for local Docker development environments to verify that the Cloud environment configuration includes the encryption key required to decrypt the database. Now, you get an error message in the log if the environment configuration does not specify a value for the encryption key. -
Added a container health check to the Elasticsearch service to ensure that the service is ready before continuing with build and deploy processing. If the health check returns an error, the container restarts automatically.
-