In this article we will see how to install and configure Apache2 web server in Ubuntu 16.04

Note: Throughout this article, we will be referring to domain name as website1-example.com. Replace this domain name with your actual domain name whenever required.

Step – 1 : Install Apache2 web server
We will begin with updating the local package to reflect the latest upstream changes. Afterwards we can install the Apache2 package.

$ sudo apt-get update
$ sudo apt-get install apache2

The status can be check by running the following commands

$ sudo systemctl status apache2

You can access the default apache landing page to confirm that the software is running properly. You can access this through your server’s domain name or IP address.

Step – 2 : Check web server
Run below command to make sure the service running

$ sudo systemctl status  apache2

Now you can access the default apache landing page to confirm that the software is running properly. You can access it through your server’s domain name or IP address.

For example: http://www.website1-example.com

Step – 3 : Create virtual host
In Apache on Ubuntu all the virtual host configuration files are stored under /etc/apache2/sites-available directory. With the new Apache installation you can find a default virtual host file called 000-default.conf there. We will create a new virtual host configuration file by copying 000-default.conf file.

$ sudo cp /etc/apache2/sites-available/000-default.conf /etc/apache2/sites-available/website1-example.com.conf

Open your virtual host file,

$ sudo nano /etc/apache2/sites-available/website1-example.com.conf

The file should look like the following:

<VirtualHost *:80>
ServerAdmin webmaster@localhost
 	DocumentRoot /var/www/html
 	ErrorLog ${APACHE_LOG_DIR}/error.log
 	CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>

Now edit this file as per your requirement. My configuration looks like below:

<VirtualHost *:8090>
ServerAdmin webmaster@website1-example.com
ServerName website1-example.com
ServerAlias www.website1-example.com
DocumentRoot /var/www/website1-example.com
<Directory /var/www/website1-example.com>
Options Indexes FollowSymLinks MultiViews
    AllowOverride All
    Require all granted
    allow from all
</Directory>
ErrorLog /var/www/website1-example.com/error.log
CustomLog /var/www/website1-example.com/access.log combined
</VirtualHost>


* ServerAdmin: Server admin’s email address.
* ServerName: The domain that should match for this virtual host configuration. This should be your domain name. i.e. website1-example.com
* ServerAlias: It is an additional matching condition that needs to be processed. i.e. http://www.website1-example.com
* DocumentRoot: The directory from which Apache will serve the domain files.
* Options: This directive controls which server features are available in a specific directory.
* ErrorLog, CustomLog: Specifies the location of log files.


Step – 4 : Create project directory
By default the document root directory is /var/www/html. We will create a website1-example.com directory in www directory as defined in the above virtual host configuration.
$ sudo mkdir /var/www/website1-example.com

Now let’s create a test HTML file called index.html in a root directory we just created in a previous step.

$ sudo nano /var/www/website1-example.com/index.html

Add the following code to the file and then save it.

<html>
<head>
<title>website1-example.com</title>
</head>
<body>
   <h2> Welcome to website1-example.com </h2>
</body>
</html>

Step – 5 : Enable the virtual host
Enable the virtual host using the a2ensite tool:

$ sudo a2ensite website1-example.com.conf

Apply the changes to Apache

$ sudo service apache2 reload

Next, open /etc/hosts file in editor and add your domain/IP address like below:

$ sudo nano /etc/hosts
 
[...]
127.0.0.1 localhost
your-domain your-sever-name.com

For example:

13.233.10.119 website1-example.com
[...]

Save and close the file.

Step – 6 : Enable CORS

Now we will enable CORS on apache2 server. CORS is a process which tells browsers to access resources from different origin (domain, protocol, port) via HTTP headers

Enable headers by typing:

$ sudo a2enmod headers
Open /etc/apache2/apache2.conf file by typing following command and add cross-origin headers in <Directory> section

$ sudo nano /etc/apache2/apache2.conf

For example:



Figure : CORS Configuration

Step – 7 : Enable ports

If you are using ports other than default port number 80 then we need to enable that port. In step 3 we have configured a virtual host on port 8090. Let’s enable port 8090 in Apache2.

Open /etc/Apache2/ports.conf file. In this file add your port number.

For example:

$ sudo nano /etc/apache2/ports.conf 
 
[...]
 
Listen 80
Listen 8090
 
[...]

Save and close the file.

Restart your apache2 service to reflect all changes.

$ sudo service apache2 restart