How to Compile and Install NGINX from Sources in Linux

Nginx is the fastest growing Webserver today on public internet-facing servers due to its free open-source modular model, high performance, stability, simple configurations files, asynchronous architecture (event-driven), and low resources needed to run.

This tutorial will guide you on installing the latest stable version of Nginx on RHEL-based distributions from sources because official system repositories don’t provide a binary package.

If you want to avoid sources installation you can add an official Nginx repository and install the binary package with the help of the yum or dnf package manager as shown:

Method 1: Install NGINX Using Yum Repository

Before you install nginx, you need to enable the nginx packages repository on RHEL and its derivatives such as CentOS, Rocky Linux, AlmaLinux, and Oracle Linux. Afterward, you can install and update nginx from the repository.

First, install the yum-utils package as shown.

# yum install yum-utils

To enable the nginx official yum repository, create the file named /etc/yum.repos.d/nginx.repo with the following contents:

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
Add Nginx Yum Repository
Add Nginx Yum Repository

Next, you can install and update nginx from the repository.

# yum install nginx
Install Nginx in Linux
Install Nginx on Linux

Important: Please note, following the above official nginx yum repositories will give you an older version of nginx, if you really want to build the most recent version of Nginx, then I suggest you follow the source installation as shown below.

Using sources compilation and installation has some benefits because you can install the latest version available, you can tweak Nginx configuration by adding or removing modules, and change the installation system path, or other important settings, in other words, you have complete control over the installation process.

Method 2: Compiling and Installing NGINX from Source

Before starting the Nginx compilation and installation process make sure that you have a C/C++ compiler, PCRE (Perl Compatible Regular Expressions), Zlib Compression Library, and OpenSSL (if you intend to run Nxing with SSL support) packages installed on your machine by issuing the following command.

# yum -y install gcc gcc-c++ make zlib-devel pcre-devel openssl-devel
Install GCC and C++ Compiler
Install GCC and C++ Compiler

Download Nginx Source

Now, go to the Nginx download page and grab the latest stable version of the Nginx source tarball using the following wget command, then extract the nginx archive and move into Nginx extracted directory as shown.

# wget http://nginx.org/download/nginx-1.23.4.tar.gz
# tar xfz nginx-1.23.4.tar.gz 
# cd nginx-1.23.4
# ls -all
Download Nginx Source Package
Download Nginx Source Package

Compile Nginx from Source

The next step is to customize the Nginx installation process using the configure file to visualize configuration options and modules needed for the Nginx compilation process using the following command.

# ./configure --help
Nginx Compilation Configuration Options
Nginx Compilation Configuration Options

Now it’s time to compile Nginx with your specific configurations and enabled or disabled modules. For this tutorial, the following modules and specifications were used, but you can tweak the compilation to whatever suits your needs.

  • --user=nginx – set the system user that Nginx will run as.
  • --group=nginx – set the system group that Nginx will run as.
  • --prefix=/etc/nginx – directory for server files (nginx.conf file and other configuration files) – default is /usr/local/nginx directory.
  • --sbin-path=/usr/sbin/nginx – Nginx executable file location.
  • --conf-path=/etc/nginx/nginx.conf – sets the name for the nginx.conf configuration file – you can change it.
  • --error-log-path=/var/log/nginx/error.log – sets Nginx error log file location.
  • --http-log-path=/var/log/nginx/access.log – sets Nginx access log file location.
  • --pid-path=/var/run/nginx.pid – sets the name for the main process ID file.
  • --lock-path=/var/run/nginx.lock – sets the name for the Nginx lock file.
  • --with-http_ssl_module – enables building the HTTPS module – not built by default and requires an OpenSSL library.
  • --with-pcre – sets the path to the sources of the PCRE library – not built by default and requires a PCRE library.

To view, a list of all Nginx modules visit the Nginx docs web page at http://wiki.nginx.org/Modules.

If you don’t need a specific module installed on Nginx you can disable it using the following command.

--without-module_name

Now start to compile Nginx by issuing the following command, which will use all the configurations and modules discussed above (make sure the command stays on a single line).

# ./configure --user=nginx --group=nginx --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --with-http_ssl_module --with-pcre
Compile Nginx from Source
Compile Nginx from Source

After the compilation process verifies all system-required utilities like GNU C compiler, PCRE, and OpenSSL libraries, it creates the make.conf file and outputs a summary of all configurations.

Nginx Compilation Summary
Configuration summary
  + using system PCRE2 library
  + using system OpenSSL library
  + using system zlib library

  nginx path prefix: "/etc/nginx"
  nginx binary file: "/usr/sbin/nginx"
  nginx modules path: "/etc/nginx/modules"
  nginx configuration prefix: "/etc/nginx"
  nginx configuration file: "/etc/nginx/nginx.conf"
  nginx pid file: "/var/run/nginx.pid"
  nginx error log file: "/var/log/nginx/error.log"
  nginx http access log file: "/var/log/nginx/access.log"
  nginx http client request body temporary files: "client_body_temp"
  nginx http proxy temporary files: "proxy_temp"
  nginx http fastcgi temporary files: "fastcgi_temp"
  nginx http uwsgi temporary files: "uwsgi_temp"
  nginx http scgi temporary files: "scgi_temp"

Build Nginx from Source

The last step is to build the binaries using make command, which can take some time to finish depending on your machine resources, and install Nginx on your system with make install command.

Be careful that the make install command requires root privileges to perform the installation, so if you’re not logged in with a root account use a privileged user with sudo.

# make
# make install

After the installation process has finished with success, add the nginx system user (with /etc/nginx/ as his home directory and with no valid shell), the user that Nginx will run as by issuing the following useradd command.

# useradd -d /etc/nginx/ -s /sbin/nologin nginx
Add Nginx User
Add Nginx User

Configure Nginx File

While compiling, we had specified that Nginx will run from the nginx system user, open nginx.conf file and change the user statement to nginx.

# nano /etc/nginx/nginx.conf
OR
# vi /etc/nginx/nginx.conf

Here locate and change the user and, also, document root location statements, with the following options.

user nginx;
location / {
                root /var/www/html;
                autoindex on;
                index index.html index.htm;
Configure Nginx User and DocumentRoot
Configure Nginx User and DocumentRoot

Before starting Nginx, assure that you have created the web document root path, then start nginx using the following command.

# mkdir -p /var/www/html
# /usr/sbin/nginx

If you want to check if Nginx is running using your shell prompt, run the netstat command to verify TCP connection.

# netstat -tulpn | grep nginx
Start Nginx Service
Start Nginx Service

Open Nginx on Firewalld

To verify Nginx from a remote system, add a Firewall rule to open connection to outside on Port 80 and 443.

# firewall-cmd --permanent --add-service=http
# firewall-cmd --permanent --add-service=https
# systemctl restart firewalld

Finally, open a browser, and direct the URL to your server IP Address at:

http://server_IP
Check Nginx Page
Check Nginx Page

Manage Nginx Service

To manage the Nginx process use the following commands.

# /usr/sbin/nginx -V         [show Nginx modules and configurations]
# /usr/sbin/nginx -h         [help options]
# /usr/sbin/nginx -t         [check configuration file]
# /usr/sbin/nginx            [start Nginx process]
# /usr/sbin/nginx -s stop    [stop Nginx process]
# /usr/sbin/nginx -s reload  [reload Nginx process]
Check Nginx Compiled Version
Check Nginx Compiled Version

If you need to manage the Nginx daemon process through a systemd script, create the following file on /lib/systemd/system/nginx.service, and, then, you can use systemctl commands to manage the process.

# vi /lib/systemd/system/nginx.service

Add the following file content.

[Unit]
Description=The NGINX HTTP and reverse proxy server
After=syslog.target network-online.target remote-fs.target nss-lookup.target
Wants=network-online.target

[Service]
Type=forking
PIDFile=/run/nginx.pid
ExecStartPre=/usr/sbin/nginx -t
ExecStart=/usr/sbin/nginx
ExecReload=/usr/sbin/nginx -s reload
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

After the Nginx systemd file is created, manage the daemon using the below commands.

# systemctl start nginx
# systemctl stop nginx
# systemctl status nginx

That’s all! Now you have the latest version of Nginx installed on your RHEL-based distributions. In the next tutorial, I will discuss how to install and enable the PHP-FPM process manager through Nginx FastCGI Gateway.

Similar Posts