This topic describes how to modify Apache configuration files to point multiple domain names to different websites deployed on a simple application server. Then, you can use the domain names to access the websites over HTTP.

Prerequisites

A simple application server is created from a Linux, Apache, MySQL, and PHP (LAMP) application image. For more information, see Build a LAMP development environment.

Background information

In the examples, the following resources are used:
  • Server: a simple application server created from the LAMP 7.4 application image.
  • Two test websites: test01 and test02.
  • Two test domain names: test01.example.com and test02.example.com.
After you complete the configurations described in this topic, you can perform the following operations:
  • Use test01.example.com to access the test01 website.
  • Use test02.example.com to access the test02 website.

In actual operations, you must replace these example resources with your own resources.

Step 1: Create test websites

If the code of your multiple websites is already stored in the root directory of websites on the server, skip this step.

  1. Connect to the LAMP server.
  2. Run the following command to go to the root directory of websites.
    The root directory of websites varies based on the LAMP versions in the LAMP application images used on simple application servers.
    • If the LAMP 7.4 application image is used on servers, the root directory of websites is /data/wwwroot/example.
    • If the LAMP 6.1.0 application image is used on servers, the root directory of websites is /home/www/htdocs.
    In this example, the LAMP 7.4 application image is used. Run the following command to go to the root directory of websites:
    cd /data/wwwroot/example
  3. Run the following commands in sequence to create two subdirectories.
    The subdirectories are used to store the code of websites.
    sudo mkdir test01
    sudo mkdir test02
  4. Go to the test01 subdirectory, and create and edit the index.html file.
    1. Run the following command to go to the test01 subdirectory:
      cd /data/wwwroot/example/test01/
    2. Run the following command to create the index.html file:
      sudo vi index.html
    3. Press the I key to enter the edit mode and add the following test information to the file:
      Test page 01
    4. Press the Esc key, enter :wq, and then press the Enter key to save and close the file.
  5. Go to the test02 subdirectory, and create and edit the index.html file.
    1. Run the following command to go to the test02 subdirectory:
      cd /data/wwwroot/example/test02/
    2. Run the following command to create the index.html file:
      sudo vi index.html
    3. Press the I key to enter the edit mode and add the following test information to the file:
      Test page 02
    4. Press the Esc key, enter :wq, and then press the Enter key to save and close the file.

Step 2: Modify Apache configuration files

  1. Modify the httpd.conf configuration file.
    1. Run the following command to open the httpd.conf configuration file:
      sudo vi /etc/httpd/conf/httpd.conf
    2. Press the I key to enter the edit mode, and modify configurations.
      Find the following configurations:
      # Virtual hosts
      #Include conf/extra/httpd-vhosts.conf
      Delete # from the beginning of the #Include conf/extra/httpd-vhosts.conf line.
      The following figure shows the lines after modification. httpd-vhosts.conf
    3. Press the Esc key, enter :wq, and then press the Enter key to save and close the file.
  2. Modify the vhosts.conf configuration file.
    1. Run the following command to open the vhosts.conf configuration file:
      sudo vi /etc/httpd/conf.d/vhost.conf
    2. Press the I key to enter the edit mode, and modify configurations.
      You must comment out the default configurations that are enclosed by the <VirtualHost *:80></VirtualHost> tags in the file and manually add multiple domain names.
      In this example, perform the following operations:
      1. Comment out the default configurations, as shown in the following figure. Default virtual host information
      2. Add the following configurations to the end of the file:
        <VirtualHost *:80>
             DocumentRoot "/data/wwwroot/example/test01"
             ServerName test01.example.com
        </VirtualHost>
        
        <VirtualHost *:80>
             DocumentRoot "/data/wwwroot/example/test02"
             ServerName test02.example.com
        </VirtualHost>
        You can configure the following parameters based on your needs:
        • DocumentRoot: the website directory. Specify this parameter in the format of DocumentRoot "<website directory>".
        • ServerName: the domain name. Specify this parameter in the format of ServerName <domain name>.
    3. Press the Esc key, enter :wq, and then press the Enter key to save and close the file.
  3. Run the following command to restart the Apache service:
    sudo systemctl restart httpd

Step 3: Bind domain names

For the two test domain names used in this example, you must add the mappings between these domain names and the public IP address of the LAMP server to the hosts file on your Windows computer.
Note If you use actual domain names when you configure the websites, skip this step. You must bind multiple domain names to the LAMP server. For more information, see Bind and resolve domain names. After domain names are bound, you can use the domain names to access the corresponding websites.
  1. Go to the C:\Windows\System32\drivers\etc directory.
  2. Copy the hosts file for backup.
    Retain the hosts - copy file, which can be used to restore the hosts file to the initial state after the test is complete.
  3. Modify the hosts file.
    Append the following information to the end of the file:
    <Public IP address of the simple application server> test01.example.com
    <Public IP address of the simple application server> test02.example.com
  4. Go back to the Windows desktop and press Win+R.
  5. In the Run dialog box, enter cmd and click OK.
  6. On the command line, run the following command to make the new configurations of the hosts file immediately take effect:
    ipconfig /flushdns

Step 4: Access the website by using the bound domain names

Use a browser to access the test websites on your Windows computer.
  • Use test01.example.com to access the test01 website, as shown in the following figure. test01
  • Use test02.example.com to access the test02 website, as shown in the following figure. test02