Windows requirements

Using WSL

1. Install WSL

To install WSL2 on Windows follow this guide.

For step #6 Install your Linux distribution of choice we recommend choosing the latest Ubuntu release, as it has the best compatibility on Windows.

1.1 Install Windows Terminal (Optional)

On Windows with WSL, it is recommended to use Windows Terminal. By using it you can open different shells and access different WSL distros in the same place, which is quite handy.

1.2 Install Visual Studio Code (Optional)

VSCode has excellent integration with WSL, so you can run commands, edit code and debug it inside a single editor. Developing in WSL.

2. Install Docker Desktop for Windows

Download and install Docker Desktop for Windows.

3. Enable WSL 2 integration in Docker Desktop settings

Go to Docker Desktop settings > General and make sure that Use the WSL 2 based engine checkbox is checked.

Then, go to Resources >WSL Integration and enable WSL integration into your distro.

Toggle your distro and click Apply & Restart.

4. Prepare the environment

If you don't have COMPOSER_AUTH environment variable or auth.json file in your project, CMA will run a setup wizard with detailed instructions for you to get access keys for the Magento repository. But you can also set up them manually by following the instructions below.

To work with Magento you need access keys to access the Magento repository.

  1. Generate Access Keypair

Now you have a public key and private key values.

To use them you have 2 options:

  1. Use COMPOSER_AUTH environmental variable

    This option is used as a global variable on your machine.

    Replace <public key> and <private key> with your public and private key.

    export COMPOSER_AUTH='{
        "http-basic":{
            "repo.magento.com": {
                "username": "<public key>",
                "password": "<private key>"
            }
        }
    }'

    Add the result to your .bashrc or .zshrc and reload your terminal.

  2. Use auth.json file

    This option is used on a per-project basis, so your credentials will be always correct no matter which project you are working on.

    Create auth.json file in the root of your project and inside put the following content using the same <public key> and <private key> you obtained before:

    {
        "http-basic":{
            "repo.magento.com": {
                "username": "<public key>",
                "password": "<private key>"
            }
        }
    }

5. Start your application

Start command description can be found here. To access Magento CLI, Composer and PHP use cli command.

Using VM

As an option, you can run CMA on Windows using a Linux VM running in Virtual Box (free) or VMWare Workstation Player (paid). We recommend using Ubuntu or Fedora distros, although Linux Mint, CentOS and distros based on apt , pacman, yum, dnf package managers should also work. Installation guide for this option is the same as installing on a regular Linux platform.

Last updated