How to Install Joomla on Ubuntu 20.04 | 18.04 with Nginx and Let’s Encrypt

For students and new users looking for an easy way to install Joomla CMS on Ubuntu with Nginx and Let’s Encrypt, then this post should come in handy.

This brief tutorial shows students and new users how to install Joomla content management system (CMS) on Ubuntu 18.04 | 20.04 with Nginx HTTP server and Let’s encrypt wildcard SSL certificates.

Joomla is an opensource, mobile friendly content management system (CMS) that provides an easy way to build dynamic and powerful websites.

You can use Joomla to power your online content websites with ease, without the need to learn how read and write complicated codes and scripts.

When you’re looking for an opensource, free, and useful CMS to run your content online, Joomla should probably be a starting point for you. And if you want to learn how to easily install and mange it, then this post is all you need.

For more about Joomla, please check their Homepage

To get started with installing Joomla, follow the steps below:

Step 1: Install Nginx HTTP Server

Joomla requires a web server to function, and Nginx is one of the most popular opensource web server available today.

To install Nginx on Ubuntu, run the commands below:

sudo apt update
sudo apt install nginx

After installing Nginx, the commands below can be used to stop, start and enable Nginx service to always start up with the server boots.

sudo systemctl stop nginx.service
sudo systemctl start nginx.service
sudo systemctl enable nginx.service

To test whether Nginx is installed and functioning, open your web browser and browse to the server’s IP address or hostname.


nginx default home page test

If you see the above page in your browser, then Nginx is working as expected.

Step 2: Install MariaDB Database Server

You’ll also need a database server to run Joomla. A database server is where Joomla content get stored.

A true open source database server that you can use with Joomla is MariaDB database server. It is fast, secure and the default server for almost all Linux servers.

To install MariaDB, run the commands below:

sudo apt-get install mariadb-server mariadb-client

After installing MariaDB, the commands below can be used to stop, start and enable MariaDB service to always start up when the server boots.

sudo systemctl stop mariadb.service
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

Next, run the commands below to secure the database server with a root password if you were not prompted to do so during the installation.

sudo mysql_secure_installation

When prompted, answer the questions below by following the guide.

  • Enter current password for root (enter for none): Just press the Enter
  • Set root password? [Y/n]: Y
  • New password: Enter password
  • Re-enter new password: Repeat password
  • Remove anonymous users? [Y/n]: Y
  • Disallow root login remotely? [Y/n]: Y
  • Remove test database and access to it? [Y/n]:  Y
  • Reload privilege tables now? [Y/n]:  Y

To verify and validate that MariaDB is installed and working, login to the database console using the commands below:

sudo mysql -u root -p

type the root password when prompted.

mariadb welcome

If you see a similar screen as shown above, then the server was successfully installed.

Step 3: Install PHP 7.4 and Related Modules

Joomla is a PHP based application, and PHP is required to run it. Since some versions of Ubuntu don’t have the latest versions of PHP, you can add a third-party PPA repository to install PHP from there.

The command below will add a third-party PPA to Ubuntu.

sudo apt-get install software-properties-common
sudo add-apt-repository ppa:ondrej/php

Then update and upgrade to PHP 7.4

sudo apt update

Next, run the commands below to install PHP 7.4 and related modules.

sudo apt install php7.4-fpm php7.4-common php7.4-mysql php7.4-gmp php7.4-curl php7.4-intl php7.4-mbstring php7.4-xmlrpc php7.4-gd php7.4-xml php7.4-cli php7.4-zip

After installing PHP 7.4, go and configure some basic settings that may be required for Joomla to function properly.

Run the commands below to open PHP

sudo nano /etc/php/7.4/fpm/php.ini

Below are good settings to configure for most Joomla websites.

file_uploads = On
allow_url_fopen = On
short_open_tag = On
memory_limit = 256M
cgi.fix_pathinfo = 0
upload_max_filesize = 100M
max_execution_time = 360
date.timezone = America/Chicago

That should get PHP 7.4 installed with some basic settings to allow Joomla to function.

Step 4: Create Joomla Database

When all the servers are installed above, it’s now time to begin setting up Joomla environment. First, run the steps below to create a blank database for Joomla to use.

Logon to MariaDB database console using the commands below:

sudo mysql -u root -p

Then create a database called joomla


Next, create a database user called joomlauser and set password

CREATE USER 'joomlauser'@'localhost' IDENTIFIED BY 'new_password_here';

Then grant the user full access to the database.

GRANT ALL ON joomla.* TO 'joomlauser'@'localhost' WITH GRANT OPTION;

Finally, save your changes and exit.


Step 5: Download Joomla

At this point, Joomla is ready to be downloaded and installed. Use the commands below to download the latest version of Joomla.

To view Joomla releases, see this page.

At the time of this writing, the latest version is 3.9.18… Future version will have different links to download from….

Run the commands below to download and extract Joomla version 3.9.18

cd /tmp
sudo unzip -d /var/www/joomla /tmp/joomla_3-9-18-stable-full_package-zip

Then run command below to allow www-data user to own the Joomla directory.

sudo chown -R www-data:www-data /var/www/joomla/
sudo chmod -R 755 /var/www/joomla/

Step 6: Configure Nginx

Below is where you configure Nginx VirtualHost file for the Joomla site you’re creating. This file defines how client requests are handled and processed.

Run the commands below to create a new VirtualHost file called joomla in the /etc/nginx/sites-available/ directory.

sudo nano /etc/nginx/sites-available/joomla

A very good configuration settings for most Joomla site on Nginx server is below. This configuration should work great.

Copy the content below and save into the file created above.

server {
    listen 80;
    listen [::]:80;
    root /var/www/joomla;
    index  index.php index.html index.htm;

    client_max_body_size 100M;
    autoindex off;
    location / {
        try_files $uri $uri/ /index.php?$args;

    # deny running scripts inside writable directories
    location ~* /(images|cache|media|logs|tmp)/.*.(php|pl|py|jsp|asp|sh|cgi)$ {
      return 403;
      error_page 403 /403_error.html;

    location ~ .php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php7.4-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;

Save the file and exit.

After saving the file above, run the commands below to enable the new site, then restart Nginx server.

sudo ln -s /etc/nginx/sites-available/joomla /etc/nginx/sites-enabled/
sudo systemctl restart nginx.service

At this stage, Joomla is ready and can be launched by going to the server’s IP or hostname.


However, if you want to enable SSL or accept web traffic over HTTPS, then you can continue below to install and configure Let’s Encrypt free SSL certificates.

Step 7: Install Let’s Encrypt Wildcard Certificates

At step 6, Joomla is ready to use without SSL. However, if you want to serve web traffic over HTTPS, then installing and configuring Let’s Encrypt SSL certificate or other public certificates is a must.

To install Let’s Encrypt, run the commands below.

sudo apt update
sudo apt-get install letsencrypt

The commands above will install certbot tool and all dependencies that will be allowed to make the tool function.

Let’s Encrypt provides many ways to challenge you to validate that you own the domain you want to provide SSL certificates for. You will not be able to generate certificates if you can’t prove that you own the domain you want to secure.

For wildcard certificates, the only challenge method Let’s Encrypt accepts is the DNS challenge, which we can invoke via the preferred-challenges=dns flag.

So, to generate a wildcard cert for domain *, you run the commands below:

sudo certbot certonly --manual --preferred-challenges=dns --email [email protected] --server --agree-tos -d -d *

The command options above are explained below:

  • certonly:                                     Obtain or renew a certificate, but do not install
  • –manual:                                    Obtain certificates interactively
  • –preferred-challenges=dns:      Use dns to authenticate domain ownership
  • –server:                                      Specify the endpoint to use to generate
  • –agree-tos:                                 Agree to the ACME server’s subscriber terms
  • -d:                                               Domain name to provide certificates for

After executing the command above, Let’s Encrypt will provide a text string to add a text record to your DNS entry…


Saving debug log to /var/log/letsencrypt/letsencrypt.log
Plugins selected: Authenticator manual, Installer None

Would you be willing to share your email address with the Electronic Frontier
Foundation, a founding partner of the Let's Encrypt project and the non-profit
organization that develops Certbot? We'd like to send you email about EFF and
our work to encrypt the web, protect its users and defend digital rights.
(Y)es/(N)o: y
Obtaining a new certificate
Performing the following challenges:
dns-01 challenge for

NOTE: The IP of this machine will be publicly logged as having requested this
certificate. If you're running certbot in manual mode on a machine that is not
your server, please ensure you're okay with that.

Are you OK with your IP being logged?
(Y)es/(N)o: y

Please deploy a DNS TXT record under the name with the following value:


Before continuing, verify the record is deployed.

Go to your DNS provider portal and add a text record for the string above and save…

Let's Encrypt DNS

Wait a few mins before continuing from the prompt.

Some DNS providers take a wile to propagate changes so it may depend on your provider’s platform.

After the changes above and Let’s encrypt is able to validate that you own the domain, you should see a successful message as below:

 - Congratulations! Your certificate and chain have been saved at:
   Your key file has been saved at:
   Your cert will expire on 2020-01-09. To obtain a new or tweaked
   version of this certificate in the future, simply run certbot
   again. To non-interactively renew *all* of your certificates, run
   "certbot renew"

The wildcard certificate is now generated and ready to be used.

To verify that the certificate is ready, run the commands below:

sudo certbot certificates

That should display similar screen as below:

Found the following certs:
  Certificate Name:
    Domains: *
    Expiry Date: 2020-01-05 07:48:04+00:00 (VALID: 85 days)
    Certificate Path: /etc/letsencrypt/live/
    Private Key Path: /etc/letsencrypt/live/

Now, Let’s Encrypt’s certificates are valid for 90 days… You’ll want to setup a crob job to automate the renewal process… To do that, open crontab and add the entry below:

sudo crontab -e

Then add the line below and save…

0 1 * * * /usr/bin/certbot renew >> /var/log/letsencrypt/renew.log

Save and you’re done!

With Let’s Encrypt installed, reopen Nginx VirtualHost file created above and add Let’s Encrypt configurations to secure your website.

Run the commands below open the file.

sudo nano /etc/nginx/sites-available/joomla

Then add the highlighted lines to the VirtualHost file as shown below:

server {
    listen 80;
    listen [::]:80;
    server_name *;
    return 301 https://$host$request_uri;
server {
    listen 443 ssl http2;
    listen [::] 443 ssl http2;
    root /var/www/joomla;
    index  index.php index.html index.htm;

    if ($host != "") {
      return 301$request_uri;

    ssl_certificate /etc/letsencrypt/live/;
    ssl_certificate_key /etc/letsencrypt/live/;
    ssl_trusted_certificate /etc/letsencrypt/live/;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_prefer_server_ciphers on;
    ssl_session_cache shared:SSL:50m;
    ssl_session_timeout 1d;
    ssl_session_tickets off;
    ssl_ecdh_curve X25519:sect571r1:secp521r1:secp384r1;

    client_max_body_size 100M;
    autoindex off;
    location / {
        try_files $uri $uri/ /index.php?$args;

    # deny running scripts inside writable directories
    location ~* /(images|cache|media|logs|tmp)/.*.(php|pl|py|jsp|asp|sh|cgi)$ {
      return 403;
      error_page 403 /403_error.html;

    location ~ .php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php7.4-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;

After the above, restart Nginx and PHP 7.4-FPM

sudo systemctl reload nginx
sudo systemctl reload php7.4-fpm

Next, open your browser and browse to the server domain name. You should see Joomla setup wizard to complete. Please follow the wizard carefully.

Then follow the on-screen instructions.

Select the installation language, Site Name, Super User account details, including email address, username and password.

Then click Next to continue.

Joomla installation on Ubuntu

On the next screen, enter the database info created above and click Next to continue.

Joomla installation on Ubuntu

Next, validate that all requirements and packages are installed.

After that, click Install to complete the wizard.

Joomla installation on Ubuntu

You can now login to the admin backend and begin setting up your website environment.

Joomla installation on Ubuntu

When you’re done, Joomla should be installed and ready to use. Login as admin and begin configuring your site.

Joomla installation on Ubuntu

That’s it!

Congratulation! You have successfully installed Joomla CMS on Ubuntu 18.04 | 20.04. If you find any error above, please use the comment form below to report it.


You may also like the post below:


  1. hi.

    I followed all the steps and all was ok until the last step

    the joomla administrator page is in text mode.

    The sample site is in graphical mode
    the initial set up of the joomla site was in graphical mode.
    But the joomla administrator page is in text mode.

    Can you help me please.

    1. hi,
      you have to set
      cgi.fix_pathinfo = 1

  2. u have to set:

  3. Hello! First thanks for this tutorial. I follow the steps and finish the step 6 but when i go to the ip of my vagrantbox y just see the welcome page of nginx. I think i follow correctly every steep. I hope you can help me!

    1. 1. nano /etc/nginx/nginx.conf
      2.[ include /etc/nginx/sites-enabled/*; ] => [ include /etc/nginx/sites-enabled/joomla; ] ,restart nginx

  4. thank you for this tutorial I have gotten this far downloaded the zip but cannot unzip or find file to unzip

    [email protected]:~$ wget
    –2021-01-31 09:49:33–
    Resolving (…, 2602:fd32:1:6a6f:6f6d:6c61:1:1
    Connecting to (||:443… connected.
    HTTP request sent, awaiting response… 303 See Other
    Location: [following]
    –2021-01-31 09:49:34–
    Resolving (…
    Connecting to (||:443… connected.
    HTTP request sent, awaiting response… 200 OK
    Length: 14009086 (13M) [application/zip]
    Saving to: ‘’ 100%[===============================================================================>] 13.36M 3.78MB/s in 3.5s

    2021-01-31 09:49:39 (3.78 MB/s) – ‘’ saved [14009086/14009086]
    [email protected]:~$ sudo unzip -d /var/www/joomla /tmp/
    unzip: cannot find or open /tmp/, /tmp/ or /tmp/

    thats as far as i can go

  5. Please i followed step 1 process but when i got to the http://localhost i received this error message
    setStart($startTime, $startMem)->mark(‘afterLoad’) : null; // Instantiate the application. $app = JFactory::getApplication(‘site’); // Execute the application. $app->execute();

    i have even tried using my serverIP, got same error
    Please i need help…. need to installl joomla as a school project

  6. U r the best thanks 4 the tuttorial i had the 2 problems of the comments but with ur answers i was able to fix its, Big thanks 4 this

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.