SSL/TLS Termination (SSL Offloader)¶
NGINX can act as an SSL/TLS termination point, handling HTTPS connections from clients and forwarding plain HTTP to backend servers.
Basic SSL Termination¶
server {
listen 443 ssl;
listen [::]:443 ssl;
http2 on;
server_name example.com;
# Certificates
ssl_certificate /etc/nginx/ssl/example.com.crt;
ssl_certificate_key /etc/nginx/ssl/example.com.key;
# Modern TLS configuration
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384;
ssl_prefer_server_ciphers off;
# Session caching
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 1d;
ssl_session_tickets off;
# OCSP Stapling
ssl_stapling on;
ssl_stapling_verify on;
resolver 1.1.1.1 8.8.8.8 valid=300s;
# Security headers
add_header Strict-Transport-Security "max-age=63072000" always;
location / {
proxy_pass http://127.0.0.1:8080;
proxy_http_version 1.1;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Connection "";
}
}
Redirect HTTP to HTTPS¶
server {
listen 80;
listen [::]:80;
server_name example.com;
return 301 https://$host$request_uri;
}
With Upstream Pool¶
upstream backend {
server 10.0.0.1:8080;
server 10.0.0.2:8080;
keepalive 32;
}
server {
listen 443 ssl;
http2 on;
server_name example.com;
ssl_certificate /etc/nginx/ssl/example.com.crt;
ssl_certificate_key /etc/nginx/ssl/example.com.key;
ssl_protocols TLSv1.2 TLSv1.3;
location / {
proxy_pass http://backend;
proxy_http_version 1.1;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Connection "";
}
}
Key Points¶
| Setting | Purpose |
|---|---|
ssl_certificate |
Certificate chain (full chain recommended) |
ssl_certificate_key |
Private key file |
ssl_protocols |
TLS versions (avoid SSLv3, TLSv1.0, TLSv1.1) |
ssl_session_cache |
Improves performance by caching SSL sessions |
X-Forwarded-Proto |
Tells backend the original protocol was HTTPS |
ssl_stapling |
Improves TLS handshake performance |
See Also¶
- SSL/TLS Configuration - Complete SSL guide
- Load Balancing - Backend distribution