72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Nginx Configuration File
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Nginx Configuration File
		
	
	
	
	
	
# Sample nginx configuration for Misskey
 | 
						|
#
 | 
						|
# 1. Replace example.tld to your domain
 | 
						|
# 2. Copy to /etc/nginx/sites-available/ and then symlink from /etc/nginx/sites-enabled/
 | 
						|
#    or copy to /etc/nginx/conf.d/
 | 
						|
 | 
						|
# For WebSocket
 | 
						|
map $http_upgrade $connection_upgrade {
 | 
						|
    default upgrade;
 | 
						|
    ''      close;
 | 
						|
}
 | 
						|
 | 
						|
proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=cache1:16m max_size=1g inactive=720m use_temp_path=off;
 | 
						|
 | 
						|
server {
 | 
						|
    listen 80;
 | 
						|
    listen [::]:80;
 | 
						|
    server_name example.tld;
 | 
						|
 | 
						|
    # For SSL domain validation
 | 
						|
    root /var/www/html;
 | 
						|
    location /.well-known/acme-challenge/ { allow all; }
 | 
						|
    location /.well-known/pki-validation/ { allow all; }
 | 
						|
    location / { return 301 https://$server_name$request_uri; }
 | 
						|
}
 | 
						|
 | 
						|
server {
 | 
						|
    listen 443 ssl http2;
 | 
						|
    listen [::]:443 ssl http2;
 | 
						|
    server_name example.tld;
 | 
						|
    ssl_session_cache shared:ssl_session_cache:10m;
 | 
						|
 | 
						|
    # To use Let's Encrypt certificate
 | 
						|
    ssl_certificate     /etc/letsencrypt/live/example.tld/fullchain.pem;
 | 
						|
    ssl_certificate_key /etc/letsencrypt/live/example.tld/privkey.pem;
 | 
						|
 | 
						|
    # To use Debian/Ubuntu's self-signed certificate (For testing or before issuing a certificate)
 | 
						|
    #ssl_certificate     /etc/ssl/certs/ssl-cert-snakeoil.pem;
 | 
						|
    #ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
 | 
						|
 | 
						|
    # SSL protocol settings
 | 
						|
    ssl_protocols TLSv1.2;
 | 
						|
    ssl_ciphers ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:AES128-SHA;
 | 
						|
    ssl_prefer_server_ciphers on;
 | 
						|
 | 
						|
    # Change to your upload limit
 | 
						|
    client_max_body_size 80m;
 | 
						|
 | 
						|
    # Proxy to Node
 | 
						|
    location / {
 | 
						|
        proxy_pass http://127.0.0.1:3000;
 | 
						|
        proxy_set_header Host $host;
 | 
						|
        proxy_http_version 1.1;
 | 
						|
        proxy_redirect off;
 | 
						|
 | 
						|
        # If it's behind another reverse proxy or CDN, remove the following.
 | 
						|
        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 https;
 | 
						|
 | 
						|
        # For WebSocket
 | 
						|
        proxy_set_header Upgrade $http_upgrade;
 | 
						|
        proxy_set_header Connection $connection_upgrade;
 | 
						|
 | 
						|
        # Cache settings
 | 
						|
        proxy_cache cache1;
 | 
						|
        proxy_cache_lock on;
 | 
						|
        proxy_cache_use_stale updating;
 | 
						|
        add_header X-Cache $upstream_cache_status;
 | 
						|
    }
 | 
						|
}
 |