Debian Ubuntu

Configure and host an application in Apache web server in Linux

Configure apache server on Linux

In our previous article, “How to install Apache web server on Linux”, we explained how to install Apache on a Linux machine. Now in this article, we will follow up with the basic configuration of Apache that will include

  • Allow Apache Traffic through Firewall
  • Managing Apache Services
  • Setting Up Virtual Hosts in Apache
  • Configure Apache to listen on a different port
  • Allow/Deny access from specific IP addresses

Prerequisites

  • Ubuntu 20.04 system
  • User with sudo privileges
  • An Apache web server installed

Note: The commands discussed in this article have been tested on Ubuntu 20.04 LTS (Focal Fossa). The same commands are also valid for Debian distribution.

Allowing Apache Traffic through Firewall

If a firewall is enabled on your OS, you will have to allow Apache traffic through it. The Apache server by default listens on port 80 for HTTP and 443 for https. In order to allow HTTP (port 80) traffic through the firewall, execute the following command in Terminal:

$ sudo ufw allow 'Apache'

To allow HTTPS (port 443) traffic through the firewall, execute the following command in Terminal:

$ sudo ufw allow 'Apache Secure'

In order to allow both HTTP (port 80) and HTTPS (port 443) traffic through in the firewall, execute the following commands in Terminal:

$ sudo ufw allow 'Apache Full'

Managing Apache Services

After installation, the Apache service automatically starts running in the background. To view the status of Apache service, issue the below command in Terminal:

$ systemctl status apache2

In the following output, active (running) status shows that the Apache service is active and running without any issues.

For manually starting the Apache service, use the below command:

$ sudo systemctl start apache2

For enabling the Apache service to automatically start at startup/boot, use the below command:

$ sudo systemctl enable apache2

For restarting the Apache service, use the below command:

$ sudo systemctl restart apache2

For stopping the Apache service, use the below command:

$ sudo systemctl stop apache2

Setting Up Virtual Hosts in Apache

Virtual host in Apache allows you to run a number of websites from a single Apache Web Server. In the following section, we will configure one virtual host for our domain “test.org”. For multiple domains, follow the same steps for each domain.

Step 1: Create a directory for your domain

The first step will be to create a directory for your domain. If you need to host multiple domains, create separate directories for every domain. For our domain test.org, we will create the directory with the following command:

$ sudo mkdir /var/www/test.org

Make sure to replace test.org with your domain name.

Step 2: Set ownership and permissions

The directory for our domain is currently owned by the root user. In order to allow other users to modify the files, we will need to change the ownership of the directory. Use the following command in Terminal do so:

$ sudo chown -R $USER:$USER /var/www/ test.org

Also, set required permissions on the domain directory. The 755 in the below command assigns read and execute permissions to everyone while the read, write and execute permissions to the owner of the file.

$ sudo chmod -R 755 /var/www/ test.org

Step 3: Create sample index.html page for your domain

Now create a sample index.html page for your domain to serve some content. Create a file index.html in the /var/www/test.org directory.

We are using the Nano editor for this purpose:

$ sudo nano /var/www/test.org/index.html

Add the following content in the file.

<html>

<head>

<title>Your test.org server block is up!</title>

</head>

<body>

<h1>This is a test page for test.org website!</h1>

</body>

</html>

Once you are done with editing, save and close the index.html file.

Now the sample index.html page has been created for our site.

Step 4: Create a new virtual host file

In Apaches, there is a default virtual host file that contains configurations for the default web server. For our domain test.org, we will create a separate virtual host file.

Issue the following command in Terminal to create the virtual host file for your domain:

$ sudo nano /etc/apache2/sites-available/test.org.conf

Add the below content in the file.

<VirtualHost *:80>
ServerAdmin [email protected]

ServerName test.org

ServerAlias www.test.org

DocumentRoot /var/www/test.org/html

ErrorLog ${APACHE_LOG_DIR}/error.log

CustomLog ${APACHE_LOG_DIR}/access.log combined

</VirtualHost>

Make sure to replace the test.org with your own domain name.

Once you are done with editing, save and close the file.

Step 5: Enable virtual host file

Now we will enable the virtual host file that we have created in the previous step. Issue the below command in Terminal to do so:

$ sudo a2ensite test.org.conf

We are not using the default virtual host file, so we can disable it. Use the following command to disable it:

$ sudo a2dissite 000-default.conf

Now reload Apache configurations using the following command:

$ systemctl reload apache2

Step 6: Configure hosts file (Optional)

If you do not have an actual domain name and only want to test the procedure using any test domain, you will need to add an entry for your domain in the /etc/hosts file.

Edit the /etc/hosts file using the following command in Terminal:

$ sudo nano /etc/hosts

Add the following entry in this file replacing the server_IP and domain_name with the IP address and domain name of your environment.

server_IP domain_name

In our example, the entry would be:

192.168.72.157 test.org

Now save and close the /etc/hosts file.

Step 6: Test for errors

Now test Apache configurations for any errors. Use the following command to do so:

$ sudo apache2ctl configtest

If everything is okay, you will the Syntax OK message in the output. You may also see the following warning message in the test result.

To suppress this message, add ServerName directive in the /etc/apache2/apache2.conf file.

Edit the /etc/apache2/apache2.conf file using following command in Terminal:

$ sudo nano /etc/apache2/apache2.conf

Add the following entry in the file replacing test.org with your domain name:

ServerName test.org

Save and close the file.

Again, test Apache for configuration errors. Now you will see the warning has removed.

Step 7: Test if Apache is serving your domain name

Now, test the setup by navigating to the following address in the address bar of your web browser.

http://domain_name

In our example, it would be:

http://test.org

The following page indicates the virtual host has been successfully configured and Apache is serving our domain name.

Configure Apache to listen on different port

By default, Apache listens to web traffic on port 80. There are some cases when you may need to change the Apache port like when some other service is already listening on port 80, ISP has blocked port 80, or you want to prevent port 80 attacks. However, remember that after changing the default port, you must have to point the browsers to the new port like http://domain_name:port_nmuber.

1. Edit the /etc/apache2/ports.conf file using the below command:

$ sudo nano /etc/apache2/ports.conf

This is the default view of the ports.conf file where you can see the port 80 configured as default port.

Change this port number to any other value you want the Apache server to listen to.

Save and close the ports.conf file once you are done with the editing.

2. Now, you will need to configure your virtual host to listen on the new port. To edit the virtual host file, use the following command in Terminal:

$ sudo nano /etc/apache2/sites-avaialble/test.org.conf file

In the above command, make sure to replace the test.org.conf with your virtual host file name.

Find the entry <VirtualHost *:80> and change the value from 80 to any number you want the Apache to listen to. For instance, to change the port number to 9090, the entry would be changed to <VirtualHost *:9090>.

Note: To set a port number, choose a value with 1024 to 65535 range.

Once done, save and close the file.

Apache can also be configured to listen on multiple ports. For instance, to set port 80 and 9090 as listening ports, add the following entries in the /etc/apache2/ports.conf file:

Listen 80

Listen 9090

Also in the /etc/apache2/sites-avaialble/test.org.conf file, add an entry in the following way:

<VirtualHost *:80 *:9090>

Once you are done, restart the Apache service using the following command in Terminal:

$ sudo systemctl restart apache2

Allow/Deny access from specific IP addresses

In the following section, we will see how to allow/deny specific IP addresses from accessing our site. We will use the .htaccess file for this purpose.

Step 1: Enable apache .htaccess

First, we will need to enable the .htaccess file. To do so, issue the following command in Terminal:

$ sudo nano /etc/apache2/sites-available/test.org.conf

After the VirtualHost block, append the following lines in the file:

<Directory /var/www/html/example.com/public_html>

Options Indexes FollowSymLinks

AllowOverride All

Require all granted

</Directory>

Now save the file and restart apache using the following command:

$ sudo systemctl apache2 restart

Step 2: Create .htaccess file

Now we will need to create .htaccess file. Navigate to the virtual host root directory.

$ cd /var/www/test.org

Then create .htaccess file here using the following command:

$ sudo nano .htaccess

Step 3: Allow/Deny IP addresses

To deny certain IP addresses from accessing your website, you will need to add entries in the .htaccess file in the following way:

order deny, allow

# To deny IP address 192.168.9.8

allow from 192.168.9.8

# To deny all IP addresses from 192.168.9.0 to 192.168.9.255

allow from 192.168.9

To allow For this purpose, IP addresses from accessing your website, you will need to add entries in the .htaccess file in the following way:
order deny, allow

# To deny all IP addresses

Deny from all

# It will allow the IP address 192.168.9.30

allow from 192.168.9.30

# It will allow all IP addresses from 192.168.9.0 through 192.168.9.255
allow from 192.168.9

That is all there is to it! In this article, you have learned the basics of Apache configurations on Linux. This includes firewall configuration, managing Apache services, setting up virtual hosts, changing default listening ports, and allowing/denying specific IPs from accessing the sites. For more information about Apache configurations, visit Apache server official documentation at http://httpd.apache.org/docs/.

Similar Posts