Install Wordpress With Nginx on AlmaLinux

By Chandrashekhar Fakirpure

Updated on Feb 07, 2024

In this tutorial, we will explain how to install Wordpress with Nginx MariaDB on AlmaLinux 9. The tutorial will guide you to install and configure Nginx as web server, PHP, MariaDB as a database.

WordPress most popular CMS. It is a free and open-source content management system written in PHP and paired with a MySQL or MariaDB database.

Install Wordpress With Nginx MariaDB on AlmaLinux 9

Prerequisite:

  • A AlmaLinux 9 dedicated server or KVM VPS .
  • A root user access or normal user with sudo privileges.

1. Keep the server up-to-date:

sudo dnf update -y

2. Install Nginx

sudo dnf install nginx -y


Start and enable Nginx service using following command:

sudo systemctl start nginx && sudo systemctl enable nginx


In case, you enabled UFW firewall and firewall block requests of the apache web server, open a port in the firewall.

sudo firewall-cmd --add-port=80/tcp --permanent
sudo firewall-cmd --add-port=443/tcp --permanent
sudo firewall-cmd --reload


Now, let’s verify the Nginx installation. Open browser and navigate to your server IP, it will show default test page.

3. Install MariaDB

First, we need to add MariaDB repo. Create a mariadb.repo file in /etc/yum.repo.d/ directory.

sudo vi /etc/yum.repos.d/mariadb.repo


We need to import the public key used by the package management system. We can import it using following command:

[mariadb]
name = MariaDB
baseurl = https://rpm.mariadb.org/10.11/rhel/$releasever/$basearch
gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck = 1


Now, run the installation command.

sudo dnf install mariadb-server -y


Start and enable the mariadb.service using following command:

sudo systemctl start mariadb && sudo systemctl enable mariadb


Login into mysql and create a database and user.

sudo mysql


We can create the database for WordPress by typing:

MariaDB [(none)]> CREATE DATABASE wordpress DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;


You can replace and call wordpress whatever you like.

Now, create a user and grant the permision of the database we have created eariler.

MariaDB [(none)]> GRANT ALL ON wordpress.* TO 'wordpressuser'@'localhost' IDENTIFIED BY 'password';


Resplace wordpressuser to your username and set password with strong password.

To refect the change run following command:

MariaDB [(none)]> FLUSH PRIVILEGES;


Once everything done, EXIT the mysql.

MariaDB [(none)]> exit;

4. Install and configure PHP

First, we need to install EPEL.

sudo dnf install epel-release -y

List available PHP module.

sudo dnf module list php

Next, enable PHP 8.1 using following command:

sudo dnf module install php:8.1

Finally, install PHP packages that required for the WordPress installation.

sudo dnf install php-fpm php-curl php-gd php-intl php-mbstring php-soap php-xml php-zip php-mysqli -y


Verify the PHP installation:

php -v


Open php.ini file and look for the parameter that sets cgi.fix_pathinfo. 

sudo vi /etc/php.ini


We will be uncommented by removing semi-colon(;) and set to 0.

cgi.fix_pathinfo=0


Once you have done, save and exit.

Next, restart php-fpm service:

sudo systemctl restart php-fpm

5. Configure Nginx 

Configure Nginx server block to use specific domain name and PHP Processor. Here we are creating new server block.

sudo vi /etc/nginx/conf.d/hostnextra.com.conf


Note:
Replace hostnextra.com with your domain name.

Add following lines:

server {
    server_name server_domain_name_or_IP;
    root /var/www/wordpress;
    index index.html index.htm index.nginx-debian.html index.php;

    location / {
        try_files $uri $uri/ /index.php$is_args$args;
    }

    location = /favicon.ico { log_not_found off; access_log off; }
    location = /robots.txt { log_not_found off; access_log off; allow all; }
    location ~* \.(css|gif|ico|jpeg|jpg|js|png)$ {
        expires max;
        log_not_found off;
    }
    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
      fastcgi_pass unix:/run/php-fpm/www.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}


Replace the server_domain_name_or_IP to your server IP or website name.

Test the configuration file.

sudo nginx -t


If there are no errors, restart the Nginx to make the necessary changes.

sudo systemctl restart nginx

6. Download and Extract WordPress

Now, we can download latest version of the WordPress. Use /tmp directory to download and extract WordPress.

cd /tmp
sudo curl -LO https://wordpress.org/latest.tar.gz


Extract the compressed file to create the WordPress directory structure:

sudo tar xzvf latest.tar.gz -C /var/www/


Next, change the wp-config-sample.php config file name to wp-config.php.

cd /var/www/wordpress/

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


Now, change the ownership to www-data user and group.

sudo chown -R nginx:nginx /var/www/wordpress/

7. WordPress configuration file

Next, we need to set up main WordPress configuration file. We need to generate WordPress secret key. WordPress provides a secure generator for these values so that you do not have to try to come up with good values on your own.

To grab secure values from the WordPress secret key generator, type:

sudo curl -s https://api.wordpress.org/secret-key/1.1/salt/


The above command will generate secret key. Copy the secret key and past it in to the WordPress configuration file wp-config.php.

sudo vi wp-config.php


Find the section that contains the dummy values for those settings.

It will looks like:

...

define('AUTH_KEY', 'put your unique phrase here');
define('SECURE_AUTH_KEY', 'put your unique phrase here');
define('LOGGED_IN_KEY', 'put your unique phrase here');
define('NONCE_KEY', 'put your unique phrase here');
define('AUTH_SALT', 'put your unique phrase here');
define('SECURE_AUTH_SALT', 'put your unique phrase here');
define('LOGGED_IN_SALT', 'put your unique phrase here');
define('NONCE_SALT', 'put your unique phrase here');

...


Delete those lines and paste in the values you copied from the command line.

Now, we need to add database name, user and password in the file also we can explicitly set the filesystem method to "direct".  Like shown below:

...

define('DB_NAME', 'wordpress');

/** MySQL database username */
define('DB_USER', 'wordpressuser');

/** MySQL database password */
define('DB_PASSWORD', 'password');

...

define('FS_METHOD', 'direct');


Note: Replace above values with the values you have set.

Save and close the file once you are finished.

8. Install Certbot

Let's secure the website using SSL. We will issue a SSL certificate using Certbot which is free to use. Use following command to install Certbot:

sudo dnf install certbot python3-certbot-nginx -y


Obtain a SSL certificate using certbot command. The Nginx plugin will take care of reconfiguring Nginx and reloading the config.

sudo certbot --nginx -d hostnextra.com


Note:
Replace hostnextra.com to your domain name.

By running certbot first time, you will be prompted to enter an email address and agree to the terms of service.

At this point, we have successfully installed everything needed. Now let's navigate to the browser and access the domain.

9. Complete the WordPress Installation

We have finished server side configurations.

In your web browser, navigate to your server’s domain name or public IP address:

http://server_domain_or_IP

 

Install wordpress on nginx HostnExtra

Select the language you would like to use and click continue, next it will ask to enter some information like site title, email id and set the admin username and password. Once every is set, click Install WordPress button. Once, the installation gets completed, click on the Log In button, it will redirect to login page. Enter admin username and password, the one you have set previously.

We have successfully installed WordPress.

In this tutorial we have explained how to install WordPress with Nginx MariaDB on AlmaLinux 9 server.