Saturday, December 3, 2011

Magento: Multi-Site, Multi-Domain Setup


One of Magento’s greatest strengths is its capabilities for scaling to support multi-store and multi-language retailing all from the same backend. In this tutorial, we will be showing you how to take advantage of Magento’s scalability by creating multiple websites with unique domain names sharing the same product catalog. (***NOTE: Each store can also be configured to offer a unique product catalog as well.)

For this example, we’ll be attempting to set up domain1.com, domain2.com and domain3.com.

Generally, Magento is installed into the folder /var/www/http, as per the Magento Installation Guide, and you can find more information related to the initial setup and configuration of any Magento installation there.  We aren’t going to through an full blown installation right now though, and for our purposes, we are going to presume that the Magento instance has already been installed in the server.

We’ll be dividing the process into steps based on the areas of configuration we will need to deal with–namely, Categories, Store Configuration in Magento Admin, Store Configuration in the Server.

1: Categories

First, will need to create our Categories.  Since all three websites will be sharing the same catalog, we will be using the default root Category in Catalog -> Categories -> Manage Categories and will be creating our categories under that root category (i.e. Clothing, Electronics, etc.).


These categories (Clothing, Electronics) should be set as both “Is Active” from the General Information tab and “Is Anchor” from the Display Settings tab for them to appear on the frontend of your Magento shop.  (***NOTE: If the websites will not be sharing the same catalog, a Root Category must be created for each website.  Thus, if there are 3 websites, there will be 3 Root Categories with subcategories under them.)

2: Store Configuration in the Magento Admin

1. Now that we have created our Categories, it’s time to create our websites by going to System -> Manage Stores and clicking the “Create Website” button.

    * Name – domain name of our new website
    * Code – a parameter that will be used in configuring the Apache web server to point to that particular domain name


2. Once the website has been created, we’ll create the store corresponding to this website by clicking on the “Create Store” button in System -> Manage Stores.

    * Website – website to which this store will be associated
    * Name – the same as the website name
    * Root Category – the root category that will be used for this store. (Refer to Step 1 for Details)


3. Then, we create the store view which is the interface that the customer will be able to access on the frontend.  Click the “Create Store View” button in System -> Manage Stores.

    * Store – store to which this view will be associated
    * Name – name of this store view (i.e. English Version, German Version, etc.)
    * Code – code for this store view
    * Status – if enabled, this store view will be accessible from our frontend, otherwise, it will not be accessible

      4. After the Store has been created, we need to configure the Unsecure Base URL and Secure Base URL under System -> Configuration -> General -> Web.  Before we set their respective base URLs, we first need to ensure that the configuration scope is set to the domain1.com website to define which site we are working on.

      Then, we modify the base URLs for both Unsecure:

      and Secure:

      with the corresponding domain name by unchecking the ”Use default [STORE VIEW]” checkbox and then save the configuration.

      5. Now we just repeat Steps 2-4 for the other two websites, domain2.com and domain3.com by replacing the fields with their respective information.

      3: Store Configuration in the Server

      1. Now we re-configure the Apache configuration file, httpd.conf, for all domains to set the DocumentRoot to our Magento directory.  In this case, the directory is /var/www/http

      <VirtualHost *:80>
          ServerAdmin webmaster@domain1.com
          DocumentRoot /var/www/http
          ServerName domain0.com
      </VirtualHost>

      <VirtualHost *:80>
          ServerAdmin webmaster@domain2.com
          DocumentRoot /var/www/http
          ServerName domain1.com
      </VirtualHost>

      <VirtualHost *:80>
          ServerAdmin webmaster@domain3.com
          DocumentRoot /var/www/http
          ServerName domai2.com
      </VirtualHost>


      2. Edit the .htaccess file at /var/www/http/.htaccess and add the following lines below:


      SetEnvIf Host www\.domain1\.com MAGE_RUN_CODE=domain1_com
      SetEnvIf Host www\.domain1\.com MAGE_RUN_TYPE=website
      SetEnvIf Host ^domain1\.com MAGE_RUN_CODE=domain1_com
      SetEnvIf Host ^domain1\.com MAGE_RUN_TYPE=website

      SetEnvIf Host www\.domain2\.com MAGE_RUN_CODE=domain2_com
      SetEnvIf Host www\.domain2\.com MAGE_RUN_TYPE=website
      SetEnvIf Host ^domain2\.com MAGE_RUN_CODE=domain2_com
      SetEnvIf Host ^domain2\.com MAGE_RUN_TYPE=website

      SetEnvIf Host www\.domain3\.com MAGE_RUN_CODE=domain3_com
      SetEnvIf Host www\.domain3\.com MAGE_RUN_TYPE=website
      SetEnvIf Host ^domain3\.com MAGE_RUN_CODE=domain3_com
      SetEnvIf Host ^domain3\.com MAGE_RUN_TYPE=website


      3. Restart Apache Server

      If you are on a Red Hat based distribution, you’ll be able to type service apache restart.  For other distributions, you’ll want to type apachectl restart.  (***NOTE: The second option here is different than “apachectl graceful” which will run a graceful restart and reload configuration files, without terminating current connections.  We don’t have any visitors to our site yet, so it’s okay to do a “apachectl restart”.)

No comments:

Post a Comment