How to Host A Website for Free at Your Home Linux System

The term web server can be used to refer to both hardware and software, or both working together. For the purpose of this guide, we will focus on the software side and see how you can host a website on your Linux box.

A web server is a software program that receives and responds to client requests via the HTTP/HTTPS protocols. Its primary purpose is to display website content which, oftentimes, is in the form of text, images, and video.

A web server can either serve static or dynamic content. Static content, as the name infers, refers to content that hardly changes and is bound to remain the same. The server sends back content to the user’s browser as is.

Dynamic content is content that often changes or is constantly updated. To serve dynamic content, a web server must also work alongside a database server and server-side scripting languages.

This guide will demonstrate how to set up an Apache web server to host a website on your Linux system for free.

Requirements

To follow along in this guide, ensure you have the following in place.

  • A dedicated Public IP address can be obtained from your ISP.
  • A Linux box, which can be a Linux server installation of your preferred OS variant. For this guide, we will use Debian 11.

Check out a few guides that can give you insights on installing a Linux server.

You also required a LAMP server installed, which is an acronym for Linux, Apache, and MySQL (this can also be MariaDB). Here are a few guides on how to install the LAMP stack in Linux.

How to Host A Website on Linux Server

In this section, we will proceed and discuss the main components of a web server.

What is Apache?

Apache is a popular free and open-source cross-platform web server that is released under Apache License 2.0. It’s one of the most widely used web servers accounting for nearly 32.2% of the web server market share.

To check the latest version of Apache available, and if it is installed on your server, run the command:

# apt-cache policy apache2 (On Debian-based OS)

From the output, you can see the parameter Installed: (none) implying that it is not installed yet. You also get information about the latest version being offered by Debian / Ubuntu repository, which in this case is 2.4.52.

Check Apache Package Availability
Check Apache Package Availability

On modern Red Hat distributions, you can check for the availability of Apache using the following dnf command as follows.

# dnf search httpd
Search Apache Package Availability
Search Apache Package Availability

From the above output, you can see that the Apache httpd package is available for download. If Apache is not installed on your system, use the ‘apt‘ or ‘dnf‘ package managers to install Apache as shown.

On Debian-based systems:

$ sudo apt install apache2 -y 	 
$ sudo systemctl start apache2	 
$ sudo systemctl enable apache2	 
$ sudo systemctl status apache2
Check Apache2 Status
Check Apache2 Status

On Red-Hat-based systems:

# dnf install httpd -y 	 
# systemctl start httpd	 
# systemctl enable httpd	 
# systemctl status httpd
Check httpd Status
Check httpd Status

What is MariaDB?

A fork of MySQL, MariaDB is one of the most popular and open-source relational database management systems. Nowadays, it’s preferred to MySQL due to its faster speeds in replication and performing queries as well as security and a vast array of storage engines.

To install MariaDB, On Debian-based systems:

	 
$ sudo apt install mariadb-server mariadb-client -y	 
$ sudo systemctl start mariadb	 
$ sudo systemctl enable mariadb	 
$ sudo systemctl status mariadb	 

The following output shows that MariaDB is installed and running as expected.

Check MariaDB Status
Check MariaDB Status

To install MariaDB, On RHEL-based systems:

	 
# dnf install mariadb-server -y	 
# systemctl start mariadb	 
# systemctl enable mariadb	 
# systemctl status mariadb	 
Verify MariaDB Status
Verify MariaDB Status

What is PHP?

PHP is a recursive acronym for PHP Hypertext Preprocessor, which is a popular general-purpose scripting language that is mostly used in web development.

To install PHP, On Debian-based systems:

	 
$ sudo apt update
$ sudo apt upgrade
$ sudo apt install  ca-certificates apt-transport-https software-properties-common
$ sudo add-apt-repository ppa:ondrej/php
$ sudo apt update
$ sudo apt install php8.0 libapache2-mod-php8.0 

To install PHP, On RHEL-based systems, you need to first enable the EPEL repository.

$ sudo dnf install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm  [RHEL 9]
$ sudo dnf install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm  [RHEL 8]

Next, enable the Remi repository, which offers the latest version of PHP on RHEL-based systems.

$ sudo dnf install -y https://rpms.remirepo.net/enterprise/remi-release-9.rpm  [RHEL 8]
$ sudo dnf install -y https://rpms.remirepo.net/enterprise/remi-release-8.rpm  [RHEL 8]

Once EPEL and Remi repositories are enabled on the system, you can install PHP as shown.

# dnf module list php
# dnf module enable php:remi-8.0 -y 
# dnf install php php-cli php-common

With all the components installed, you can now build your website using WordPress CMS, which is software that makes it easy or users to develop and manage a website without necessarily having knowledge of web design languages such as HTML, CSS, PHP, and Javascript.

Creating a Simple Website Using WordPress in Linux

For demonstration, we will install WordPress on Debian 11 and RHEL 9 systems, which will provide a sample website that can be further customized to your preference.

This section assumes that you already have the LAMP stack installed.

Step 1: Install Additional PHP Modules

To proceed, install additional PHP modules that are required by WordPress as shown.

To install PHP modules, On Debian-based systems:

$ sudo apt install php libapache2-mod-php php-pear php-cgi php-common php-mbstring php-zip php-net-socket php-gd php-mysql php-bcmath

To install PHP modules, On RHEL-based systems:

# dnf install php-gd php-soap php-intl php-mysqlnd php-pdo php-bcmath php-curl php-zip php-xmlrpc wget

Step 2: Create a Database for WordPress

Written in PHP, WordPress is a data-driven, free, and open-source content management system. A database is an essential component of WordPress.

The database is used to store all the blog posts, pages, categories, comments, themes, plugins as well as WordPress configuration files.

To create a database for WordPress, login to the MariaDB database server:

$ sudo mysql -u root -p

Next, create a database as shown

CREATE DATABASE wordpress_db;

Next, create a database user and assign all privileges to the user on the database.

GRANT ALL PRIVILEGES ON wordpress_db.* to wordpress_user@localhost identified by 'P@ssword321';

Then finally reload the grant tables to save the changes made and exit the database.

FLUSH PRIVILEGES;
QUIT;

Step 3: Download WordPress

With the database in place, proceed and download the latest WordPress tarball file using the wget command.

$ wget https://wordpress.org/latest.tar.gz

Once downloaded, extract the compressed file using the tar command.

$ tar -xvzf latest.tar.gz

The command extracts the contents of the file into a folder called wordpress. Move or copy the folder into the Document Root for the Apache webserver.

$ sudo mv wordpress/ /var/www/html/

Next, assign the following permissions and ownership rights.
$ sudo chmod 755 -R /var/www/html/wordpress/
$ sudo chown -R www-data:www-data /var/www/html/wordpress/

Step 4: Create an Apache Virtual Host for WordPress

The terminology virtual host refers to the practice of hosting multiple websites on a single server. If you intend to host multiple websites on a single server, you need to create a virtual host for each website.

In this case, you need to create a Virtual host for the WordPress website as follows.

$ sudo nano /etc/apache2/sites-available/wordpress.conf  [On Debian]
# vi /etc/httpd/conf/httpd.conf [On RHEL]

Paste the following lines of code to define the virtual host. For the ServerName directive, provide the server’s IP address or Fully Qualified Domain Name, which should point to the dedicated public IP address.

<VirtualHost *:80>
     ServerAdmin admin@your_domain.com
     DocumentRoot /var/www/html/wordpress
     ServerName 192.168.0.100

     <Directory /var/www/html/wordpress>
          Options FollowSymlinks
          AllowOverride All
          Require all granted
     </Directory>

     ErrorLog ${APACHE_LOG_DIR}/your-domain.com_error.log
     CustomLog ${APACHE_LOG_DIR}/your-domain.com_access.log combined

</VirtualHost>

Save the changes and exit the file.

To connect to the database, some additional modifications are needed. So, navigate into the wordpress folder.

$ cd /var/www/html/wordpress/

Next, update the wp-config.php file with the contents of the wp-config-sample.php file.

$ cp wp-config-sample.php wp-config.php
$ sudo nano wp-config.php

Next, update the database name, db username, and password directives with the database details.

Next, enable the new WordPress site as follows on Debian-based systems.

$ sudo ln -s /etc/apache2/sites-available/wordpress.conf /etc/apache2/sites-enabled/wordpress.conf
$ sudo a2ensite wordpress
$ sudo a2enmod rewrite
$ sudo a2dissite 000-default

To effect the changes, restart Apache.

$ sudo systemctl restart apache2   [On Debian]
# systemctl restart httpd  [On RHEL]

Step 4: Complete WordPress Setup on a Browser

To complete the setup, browse your web server’s IP address as shown:

http://server-ip

You should get the WordPress welcome page displayed as shown. Select your preferred language and click ‘Continue’.

WordPress Installation Setup
WordPress Installation Setup

Next, fill in the site details.

WordPress Site Details
WordPress Site Details

Then click ‘Install WordPress’ to complete the WordPress setup.

Install WordPress
Install WordPress

If everything went right, you will get a confirmation that the installation was successful. To log in, click the ‘Log In‘ button.

WordPress Admin Login
WordPress Admin Login

This ushers you to the WordPress dashboard as you can see. At this point, you can experiment with various themes to enhance the appearance of your sample website.

WordPress Admin Dashboard
WordPress Admin Dashboard

Step 5: Access WordPress Using Port Forwarding

Since you are self-hosting your web server from a Linux system at home or your Local Area Network (LAN), the next step is to make it accessible to external users or users outside your LAN (Local Area Network). This is where port forwarding comes in.

Port forwarding, also referred to as port mapping, is a technique that allows external devices to access servers or resources within a private network over the internet. The whole idea is to access private networks from outside, without which it would be impossible since external devices cannot communicate with internal IP addresses.

In your setup, you need to forward the port on which the web server is listening, (in most cases, this is port 80 for HTTP traffic or 443 for HTTPS) as well the static private IP address of the web server.

So, log in to your router and head over to the Port forwarding section. In our example, we are using the DLink router to port forward the web server’s ports (80 and 443) and private IP (192.168.0.100) to the Dedicated IP Public IP assigned by the ISP.

In your case, specify the ports and private IP of the web server and save the changes.

Port Forwarding for WordPress
Port Forwarding for WordPress

To save the changes, you might be required to reboot the router. So, go ahead and do exactly that.

Once the port forwarding is properly carried out, you can now reach your web server outside your network via the Public IP address.

Conclusion

In this guide, we have demonstrated how you can self-host your web server using Apache on a Linux box. Your feedback on this guide is welcome.

If you read this far, tweet to the author to show them you care. Tweet a thanks
James Kiarie
This is James, a certified Linux administrator and a tech enthusiast who loves keeping in touch with emerging trends in the tech world. When I'm not running commands on the terminal, I'm taking listening to some cool music. taking a casual stroll or watching a nice movie.

Each tutorial at TecMint is created by a team of experienced Linux system administrators so that it meets our high-quality standards.

Join the TecMint Weekly Newsletter (More Than 156,129 Linux Enthusiasts Have Subscribed)
Was this article helpful? Please add a comment or buy me a coffee to show your appreciation.

87 thoughts on “How to Host A Website for Free at Your Home Linux System”

  1. How can we add a minimum amount of security? also, can we proceed with the above steps using a Linux installed inside a Virtualbox in windows?

    Reply
  2. Assuming 100 concurrent web users at a time visiting my server, is it possible to handle if my web-server is a desktop with 2Gb ram and 4Gb GPU attached??

    Reply
  3. Hi, I already made a web server on my Kali Linux and also do a port forwarding on virtual server tab but my web page only access from the device which are connected with my home wifi or the same network on which server is connected but i want it to be access from world wide what can i do for that please help me thanks.

    Reply
    • @Moeez,

      Please have a public IP address setup on the server to make a web sever page accessible from outside world.

      Reply
      • I got my public IP by searching on Google “what is my ip” but with that ip my webserver is not accessible from outside world if we try to access from outside world then it give error that web page at http://my public ip could not be loaded because “net::err_connection_timed_out. this error happen when i try to access my webserver from outside local internet from mobile what should i do now or from where i can get the public ip address

        Reply
        • @Moeez,

          You need to buy the Public IP address for your web server or else take hosting from cheap hosting provider they will provide you free IP address for your web server…

          Reply
  4. Instead of manually installing webserver and stack manually, isn’t it better to host PHP site with platform like Cloudways, where the these packages are installed and configured automatically? This will save a lot of time, which you can instead spend on building your app.

    Reply
  5. Hi mate, thanks for the great article, I followed your step of installing Drupal and after copying the extracted Drupal contents to /var/www, I wasn’t greeted with the page as you showed in the screenshot.

    It’s the same Apache greeting page. So I tried to move those contents again into var/www/html directory again and still getting greeted with the same Apache default page. Could you tell me if I’m doing anything wrong? Thanks

    Reply

Got something to say? Join the discussion.

Thank you for taking the time to share your thoughts with us. We appreciate your decision to leave a comment and value your contribution to the discussion. It's important to note that we moderate all comments in accordance with our comment policy to ensure a respectful and constructive conversation.

Rest assured that your email address will remain private and will not be published or shared with anyone. We prioritize the privacy and security of our users.