×
Community Blog The Ultimate Guide to SSL for NGINX: Protecting Your Online Presence

The Ultimate Guide to SSL for NGINX: Protecting Your Online Presence

In this guide, we will walk you through the process of setting up SSL on the NGINX web server. In this post, we will explain two different methods to implement SSL on NGINX.

Securing your NGINX web server is essential to protect your online resources in today's digital landscape. Securing your website will boost your website's trustworthiness and ensure the privacy of your users' information. SSL is a secure socket layer protocol that safeguards your data and ensures your users' privacy. It creates a secure and encrypted connection between your web server and the user's browser to protect sensitive information, such as login credentials and personal details.

In this guide, we will walk you through the process of setting up SSL on the NGINX web server. In this post, we will explain two different methods to implement SSL on NGINX.

Prerequisites

Before we get started, make sure you have the following:

  • A running NGINX web server.
  • A domain or subdomain pointing to your server's IP address.
  • A root user or a user with sudo privileges.

Secure NGINX Using Self-Signed SSL

A self-signed certificate is not signed by a certificate authority. It is designed for the internal network and development environment. It is not suitable for production environments.

Here are the steps to implement self-signed SSL on the NGINX server.

Step 1 - Create a private key and a certificate signing request (CSR) using the following command.

openssl req -nodes -newkey rsa:2048 -keyout /etc/ssl/my-private.key -out /etc/ssl/my-request.csr

Provide your certificate information as shown below:

You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
Country Name (2 letter code) \[AU]:US

State or Province Name (full name) \[Some-State]:FL
Locality Name (eg, city) \[]:newyork
Organization Name (eg, company) \[Internet Widgits Pty Ltd]:alibaba
Organizational Unit Name (eg, section) \[]:IT
Common Name (e.g. server FQDN) \[]:domain.com
Email Address \[]:

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password \[]:
An optional company name \[]:

Step 2 - Generate the SSL certificate using the above certificate.

openssl x509 -in /etc/ssl/my-request.csr -out /etc/ssl/certificate.crt -req -signkey /etc/ssl/my-private.key -days 365

You will see the following output.

Certificate request self-signature ok
subject=C = US, ST = FL, L = newyork, O = alibaba, OU = IT, CN = domain.com

Step 3 - Next, you will need to edit your NGINX virtual host configuration file and configure it to use the generated SSL.

nano /etc/nginx/conf.d/your-website.conf

Add the following configurations:

server {

listen 443 ssl;
server_name your-domain.com;
ssl_certificate /etc/ssl/certificate.crt;
ssl_certificate_key /etc/ssl/my-private.key;
ssl_protocols TLSv1.2;
ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';
ssl_prefer_server_ciphers on;

\# ... other server configuration ...

}

Save and close the file then reload NGINX to apply the SSL configuration:

systemctl reload nginx

Finally, open your web browser and access your website to test the SSL.

Secure NGINX Using Commercial SSL

In this method, you will need to buy SSL certificate from any trusted Certificate Authority (CA) or any authorized reseller of SSL certificate. 

Here's a step-by-step guide on how to secure Nginx using a commercial SSL certificate:

Step 1 - Purchase an SSL certificate from any trusted CA. You will need to provide information about your domain and organization during the purchase process.

Step 2 - After completing the purchasing process, CA will send you the SSL certificate and intermediate certificate via email.

Step 3 - After obtaining all certificates, you will need to upload all files to your server using any secure file transfer methods. Place all files at default location /etc/nginx/ssl/.

Step 4 - Edit the NGINX virtual host configuration file for your website.

nano /etc/nginx/conf.d/your-website.conf

Add the following configurations to define the path of your SSL certificates.

server {
listen 443 ssl;
server_name your-domain.com;

ssl_certificate /etc/nginx/ssl/your_domain.crt;
ssl_certificate_key /etc/nginx/ssl/your_domain.key;
ssl_trusted_certificate /etc/nginx/ssl/intermediate.crt;

\# ... other server configuration ...

}

Save and close the file when you are done then restart the NGINX service to apply the changes.

systemctl restart nginx

Step 5 - Open your web browser and access your website securely using the URL https://your-domain.com. You can also use the online SSL testing tool like SSL Lab to verify your SSL.

Conclusion

In this guide, we showed you two different ways to secure your NGINX server with an SSL certificate. You can now follow any of the above methods to implement an SSL on the NGINX server to safeguard your users' privacy and website data.

0 1 0
Share on

Hiteshjethva

38 posts | 4 followers

You may also like

Comments

Hiteshjethva

38 posts | 4 followers

Related Products