Skip to content

Setup SSL for Nginx

This guide will help you set up SSL for your Nginx server on Ubuntu using Certbot. We will use a subdomain from GoDaddy, and the steps include installing Certbot, configuring Nginx, and generating an SSL certificate.

Play

Prerequisites

Before going forward, make sure you have the following prerequisites:

  • A server with root access
  • A domain name or IP address
  • A web server that can be used to serve static files
  • Nginx installed and configured on the machine

Install Certbot and the Nginx Plugin

First, install Certbot and the Nginx plugin using the following command:

Terminal window
sudo apt install certbot python3-certbot-nginx

Configure Nginx

Edit your Nginx configuration file to include your server name. Open the file with a text editor:

Terminal window
sudo vim /etc/nginx/sites-available/default

Add your subdomain in the server_name directive:

server {
...
server_name test.chaicode.com;
...
}

Save the file and exit the editor. Then, test your Nginx configuration:

Terminal window
sudo nginx -t

Create an A Record in Your Domain Registrar

Log in to your domain registrar (e.g., GoDaddy) and create an A record pointing to the IP address of your server.

  • Record Type: A
  • Name: test.chaicode.com
  • Value: IPv4 address of the server

NOTE: Its always a good idea to create a elastic/static IP for your server. This will make sure that your IP address doesn’t change on restart or reboot.

Obtain an SSL Certificate

Run Certbot to obtain an SSL certificate for your subdomain:

Terminal window
sudo certbot --nginx -d test.chaicode.com

Follow the prompts:

  1. Enter the email address associated with your domain registrar account.
  2. Accept the terms of service.
  3. Press Enter to continue.

Certbot will automatically configure your Nginx to use the new certificate. You should see a message indicating that the certificate was successfully issued.

Site Access

Access Your Site

You can now access your site using HTTPS:

Terminal window
https://test.chaicode.com
Site Access

Renewing the Certificate

To check if the certificate is close to expiring, run:

Terminal window
sudo certbot renew --dry-run

To renew the certificate, run:

Terminal window
sudo certbot renew

This guide ensures that your Nginx server is secured with SSL, making your site accessible over HTTPS.

Summary

In this guide, we learned how to set up SSL for Nginx on Ubuntu using Certbot. We installed Certbot and the Nginx plugin, configured Nginx, created an A record in your domain registrar, and obtained an SSL certificate. We also learned how to renew the certificate.

Start your journey with ChaiCode

All of our courses are available on chaicode.com. Feel free to check them out.