How to Redirect URLs in Nginx

NGINX is a high-performance web server and reverse proxy server renowned for its ability to handle high traffic loads and serve static content efficiently. One of its powerful features is the ability to redirect URLs, a crucial capability for managing web traffic, improving SEO, and ensuring a smooth user experience. URL redirection in NGINX can be used for various purposes, such as redirecting HTTP to HTTPS, creating URL aliases, or managing site migrations.

The following guide will demonstrate how to redirect URLs in NGINX using the command-line terminal on Linux or Unix-like systems. By configuring NGINX’s robust and flexible redirection capabilities, you can efficiently manage and control web traffic to meet your specific requirements.

Return Redirect URLs in NGINX

NGINX provides two key directives for setting up URL redirection: return and rewrite. These directives are crucial for directing web traffic from one URL to another.

301 Redirects in NGINX

The 301 redirect is essential for permanent redirection. It’s commonly used when a website or webpage has been permanently moved to a new URL. To set up a 301 redirect in NGINX, you use the return directive within your server block, specifying a 301 status code. This ensures that both users and search engines are directed to the new URL.

Example of a 301 Redirect

Consider you need to redirect traffic from oldsite.com to newsite.com. The NGINX configuration would look like this:

server {
    listen 80;
    server_name oldsite.com;
    location / {
        return 301 $scheme://www.newsite.com$request_uri;
    }
}

This configuration efficiently redirects all incoming requests from oldsite.com to www.newsite.com, maintaining the original request URI. This straightforward yet powerful method ensures users and search engines find your new website location.

302 Redirects in NGINX

In contrast to permanent redirection, a 302 redirect is used for temporary redirection scenarios. For example, you might temporarily redirect users during website maintenance or when a page is moved temporarily.

Example of a 302 Redirect

To illustrate, let’s say you want to redirect traffic from temp.com to another-site.com temporarily. The NGINX setup would be:

server {
    listen 80;
    server_name temp.com;
    location / {
        return 302 $scheme://www.another-site.com$request_uri;
    }
}

In this configuration, all traffic to temp.com is temporarily rerouted to www.another-site.com. The use of a 302 status code indicates that this redirection is temporary, which is important for maintaining SEO integrity during short-term changes.

Rewrite Directive Redirect URLs in NGINX

The rewrite directive in NGINX is a powerful tool for handling complex URL redirection scenarios. Unlike the straightforward return directive, rewrite leverages regular expressions and a wider range of variables. This flexibility allows for precise control over how URLs are redirected, especially in scenarios where simple redirection is insufficient.

Redirection Based on File Extension

Redirecting Specific File Types

A common requirement is to redirect specific file types. For example, redirecting all .jpg image requests to a new directory:

server {
    listen 80;
    server_name www.example.com;
    location ~* \.jpg$ {
        rewrite ^/images/(.*)\.jpg$ /new-images/$1.jpg permanent;
    }
}

In this configuration, any request to a .jpg file in the /images/ directory gets redirected to /new-images/. The regular expression \.(jpg)$ ensures that only URLs ending with .jpg are affected.

Dynamic Redirection Based on URI

Redirection with URI Manipulation

Another common scenario involves dynamically redirecting URLs based on their URI components. Consider redirecting users based on product categories:

Advertisement
server {
    listen 80;
    server_name www.example.com;
    location ~* ^/category/(.*)$ {
        rewrite ^/category/(.*)$ /new-category/$1 permanent;
    }
}

This setup captures any URL under /category/ and redirects it to a corresponding URL under /new-category/, maintaining the latter part of the URI.

Handling Legacy URL Structures

Redirecting Old URLs to New Pattern

Websites often change their URL structure over time. The rewrite directive can smoothly handle such transitions:

server {
    listen 80;
    server_name www.example.com;
    location ~* ^/old-structure/(.*)$ {
        rewrite ^/old-structure/(.*)/info$ /new-structure/$1/details permanent;
    }
}

This example shows how to redirect URLs from an old pattern (/old-structure/[identifier]/info) to a new pattern (/new-structure/[identifier]/details).

Geographic-Based Redirection

Redirecting Users by Geographic Location

NGINX can also handle redirection based on geographic location, utilizing the $geoip_country_code variable:

server {
    listen 80;
    server_name www.example.com;
    if ($geoip_country_code = "US") {
        rewrite ^/(.*)$ /us/$1 permanent;
    }
}

In this configuration, visitors from the United States are redirected to a U.S.-specific section of the website. This approach requires the GeoIP module to be enabled in NGINX.

Load Balancing Redirect URLs in NGINX

NGINX excels in efficiently managing network traffic through its load balancing and redirection capabilities. Load balancing in NGINX involves distributing incoming traffic across multiple servers. This strategy prevents any single server from becoming overloaded, thereby enhancing the system’s overall performance and reliability.

Configuring NGINX for Load Balancing

Load Balancing Setup

Basic Load Balancing

Here’s an example of how to configure NGINX for load balancing:

http {
    upstream backend {
        server backend1.example.com;
        server backend2.example.com;
        server backend3.example.com;
    }
    
    server {
        listen 80;
        
        location / {
            proxy_pass http://backend;
        }
    }
}

In this configuration, NGINX acts as a reverse proxy and evenly distributes incoming requests to one of the three specified backend servers: backend1.example.com, backend2.example.com, and backend3.example.com. This setup is crucial for high-traffic websites, as it ensures efficient request handling, thereby maintaining fast response times and minimizing server downtime.

Advanced Load Balancing with Health Checks

For improved reliability, you can configure NGINX to perform health checks on backend servers and only send traffic to healthy ones:

http {
    upstream backend {
        server backend1.example.com;
        server backend2.example.com;
        server backend3.example.com;
        
        # Enable health checks
        health_check;
    }
    
    server {
        listen 80;
        
        location / {
            proxy_pass http://backend;
        }
    }
}

With this setup, NGINX periodically checks the health of backend servers and excludes any servers that are down from the load balancing pool. This ensures that traffic is only directed to servers that are capable of handling requests, improving overall reliability.

Best Practices for Load Balancing

Implementing Session Persistence (Sticky Sessions)

For applications that require session persistence, you can use sticky sessions to ensure that a user is consistently routed to the same backend server:

http {
    upstream backend {
        ip_hash;
        server backend1.example.com;
        server backend2.example.com;
        server backend3.example.com;
    }
    
    server {
        listen 80;
        
        location / {
            proxy_pass http://backend;
        }
    }
}

In this configuration, the ip_hash directive ensures that requests from the same client IP address are always routed to the same backend server, maintaining session consistency.

Configuring SSL Termination

For secure communications, it’s a best practice to terminate SSL at the load balancer:

Advertisement
http {
    upstream backend {
        server backend1.example.com;
        server backend2.example.com;
        server backend3.example.com;
    }
    
    server {
        listen 443 ssl;
        ssl_certificate /etc/nginx/ssl/nginx.crt;
        ssl_certificate_key /etc/nginx/ssl/nginx.key;
        
        location / {
            proxy_pass http://backend;
        }
    }
}

In this setup, NGINX handles SSL termination, decrypting incoming SSL requests and forwarding them to the backend servers as regular HTTP requests. This offloads the SSL processing from the backend servers, improving their performance.

Conclusion

In this guide, we’ve explored the practicalities of using NGINX for URL redirection, load balancing, and more. We covered a range of techniques, from setting up basic 301 and 302 redirects to implementing complex rewrite rules and efficient load balancing configurations. The power of NGINX lies in its flexibility and performance, making it an invaluable tool for managing any website, whether small or large-scale. As you apply these concepts, keep experimenting and optimizing. NGINX is a robust tool in your web administration arsenal, so use it to keep your site running smoothly and efficiently.

Leave a Comment