Magento 2, multi domain setup
Configure local installation
To configure your local installation to use multiple stores, see Multiple websites or stores in the Configuration Guide.
After successfully creating and testing the local installation to use multiple stores, you must prepare your integration environment:
-
Configure routes or locations—specify how incoming URLs are handled by Adobe Commerce
-
Set up websites, stores, and store views—configure using the Adobe Commerce Admin UI
-
Modify variables—specify the values of the
MAGE_RUN_TYPE
andMAGE_RUN_CODE
variables in themagento-vars.php
file -
Deploy and test environments—deploy and test the
integration
branch
Configuration updates to Pro environments
routes.yaml
file and the cron configuration in the .magento.app.yaml
file. Adobe recommends updating and testing YAML configuration files in an Integration environment, then deploying changes to the Staging environment. If your changes are not applied to Staging sites after you redeploy and there are no related error messages in the log, then you MUST Submit an Adobe Commerce Support ticket that describes the attempted configuration changes. Include any updated YAML configuration files in the ticket.Configure routes for separate domains
Routes define how to process incoming URLs. Multiple stores with unique domains require you to define each domain in the routes.yaml
file. The way you configure routes depends on how you want your site to operate.
To configure routes in an integration environment:
-
On your local workstation, open the
.magento/routes.yaml
file in a text editor. -
Define the domain and subdomains. The
mymagento
upstream value is the same value as the name property in the.magento.app.yaml
file. -
Save your changes to the
routes.yaml
file. -
Continue to Set up websites, stores, and store views.
Configure locations for shared domains
Where the routes configuration defines how the URLs are processed, the web
property in the .magento.app.yaml
file defines how your application is exposed to the web. Web locations allow more granularity for incoming requests. For example, if your domain is store.com
, you can use /first
(default site) and /second
for requests to two different stores that share a domain.
To configure a new web location:
-
Create an alias for the root (
/
). In this example, the alias is&app
on line 3. -
Create a pass-through for the website (
/website
) and reference the root using the alias from the previous step.The alias allows
website
to access values from the root location. In this example, the websitepassthru
is on line 21.
To configure a location with a different directory:
-
Create an alias for the root (
/
) and for the static (/static
) locations. -
Create a subdirectory for the website under the
pub
directory:pub/<website>
-
Copy the
pub/index.php
file into thepub/<website>
directory and update thebootstrap
path (/../../app/bootstrap.php
). -
Create a pass-through for the
index.php
file. -
Commit and push the changed files.
pub/<website>/index.php
(If this file is in.gitignore
, the push may require the force option.).magento.app.yaml
Set up websites, stores, and store views
In the Admin UI, set up your Adobe Commerce Websites, Stores, and Store Views. See Set up multiple websites, stores, and store views in the Admin in the Configuration Guide.
It is important to use the same name and Code of your websites, stores, and store views from your Admin when you set up your local installation. You need these values when you update the magento-vars.php
file.
Modify variables
Instead of configuring an NGINX virtual host, pass the MAGE_RUN_CODE
and MAGE_RUN_TYPE
variables using the magento-vars.php
file in your project root directory.
To pass variables using the magento-vars.php
file:
-
Open the
magento-vars.php
file in a text editor.The default
magento-vars.php
file should look like the following: -
Move the commented
if
block so that it is after thefunction
block and no longer commented. -
Replace the following values in the
if (isHttpHost("example.com"))
block:-
example.com
—with the base URL of your website -
default
—with the unique CODE for your website or store view -
store
—with one of the following values:website
—load the website in the storefrontstore
—load a store view in the storefront
For multiple sites using unique domains:
For multiple sites with the same domain, you have to check the host and the URI:
-
-
Save your changes to the
magento-vars.php
file.
Deploy and test on the integration server
Push your changes to your Adobe Commerce on cloud infrastructure integration environment and test your site.
-
Add, commit, and push code changes to the remote branch.
-
Wait for deployment to complete.
-
After deployment, open your Store URL in a web browser.
With a unique domain, use the format:
http://<magento-run-code>.<site-URL>
For example,
http://french.master-name-projectID.us.magentosite.cloud/
With a shared domain, use the format:
http://<site-URL>/<magento-run-code>
For example,
http://master-name-projectID.us.magentosite.cloud/french/
-
Test your site thoroughly and merge the code to the
integration
branch for further deployment.
Deploy to Staging and Production
Follow the deployment process for deploying to Staging and Production. For Starter and Pro environments, you use the Cloud Console to push code across environments.
Adobe recommends fully testing in the Staging environment before pushing to the Production environment. Make code changes in the integration environment and begin the process to deploy across environments again.