spomeni/nginx/conf.d/production.conf
2026-06-20 18:17:30 +02:00

53 lines
1.3 KiB
Plaintext

upstream nextjs {
server app:3000;
}
server {
listen 80;
server_name testbed.mk *.testbed.mk;
location /.well-known/acme-challenge/ {
root /var/www/certbot;
}
location / {
return 301 https://$host$request_uri;
}
}
server {
listen 443 ssl;
http2 on;
server_name testbed.mk *.testbed.mk;
ssl_certificate /etc/letsencrypt/live/testbed.mk/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/testbed.mk/privkey.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
proxy_pass http://nextjs;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
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;
set $subdomain "";
if ($host ~* "^([a-z0-9-]+)\.testbed\.mk$") {
set $subdomain $1;
}
proxy_set_header X-Subdomain $subdomain;
}
location /_next/static/ {
proxy_pass http://nextjs;
proxy_cache_valid 200 365d;
add_header Cache-Control "public, immutable";
}
}