dream-setup/nginx/nginx.conf

86 lines
2 KiB
Nginx Configuration File
Raw Permalink Normal View History

2025-01-07 15:27:56 +01:00
user nginx;
worker_processes auto;
2025-01-07 16:17:23 +01:00
error_log /var/log/nginx/error.log notice;
2025-01-07 15:27:56 +01:00
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_user [$time_local] "$request" '
2025-01-07 16:17:23 +01:00
'$status $body_bytes_sent bytes "$http_referer" '
'"$http_x_forwarded_for"';
# While I removed PII from the above log format, still better not logging
access_log /dev/null main; # /var/log/nginx/access.log main;
2025-01-07 15:27:56 +01:00
server_tokens off;
sendfile on;
tcp_nopush on;
quic_retry on;
quic_gso on;
2025-01-08 11:06:09 +01:00
ssl_early_data on; # READ https://blog.cloudflare.com/introducing-0-rtt/#whats-the-catch
2025-01-07 15:27:56 +01:00
keepalive_timeout 65;
gzip on;
2025-01-08 10:41:03 +01:00
gzip_types *;
gzip_min_length 1000;
gzip_proxied any;
2025-01-07 16:08:34 +01:00
http2 on;
add_header Alt-Svc 'h3=":443"; ma=86400';
2025-01-07 15:39:12 +01:00
# modern configuration
ssl_protocols TLSv1.3;
ssl_ecdh_curve X25519:prime256v1:secp384r1;
ssl_prefer_server_ciphers off;
2025-01-07 16:08:34 +01:00
# Make sure to generate it first
2025-01-08 12:31:32 +01:00
ssl_dhparam dhparam.pem;
2025-01-07 16:08:34 +01:00
2025-01-07 15:39:12 +01:00
# OCSP stapling
ssl_stapling on;
ssl_stapling_verify on;
# replace with the IP address of your resolver;
# async 'resolver' is important for proper operation of OCSP stapling
2025-01-08 12:31:32 +01:00
resolver [2001:4860:4860::8888] [2001:4860:4860::8844];
2025-01-07 15:39:12 +01:00
# If certificates are marked OCSP Must-Staple, consider managing the
# OCSP stapling cache with an external script, e.g. certbot-ocsp-fetcher
# HTTPS redirect
server {
listen 80 default_server;
listen [::]:80 default_server;
return 301 https://$host$request_uri;
}
2025-01-07 15:41:27 +01:00
# default HTTPS server
server {
listen 443 ssl default_server;
listen 443 quic reuseport default_server;
listen [::]:443 ssl default_server;
2025-01-07 17:31:52 +01:00
server_name _;
2025-01-07 16:08:34 +01:00
# Make sure to generate
ssl_certificate snakeoil.pem;
ssl_certificate_key snakeoil.key;
2025-01-07 15:41:27 +01:00
}
2025-01-07 15:27:56 +01:00
include /etc/nginx/conf.d/*.conf;
}