# Bloco para redirecionar todo o tráfego HTTP para HTTPS server { if ($host = katalog.itguys.com.br) { return 301 https://$host$request_uri; } # managed by Certbot listen 80; listen [::]:80; server_name katalog.itguys.com.br; location / { return 301 https://$host$request_uri; } } # Bloco principal para o site HTTPS com cache inteligente server { listen 443 ssl http2; listen [::]:443 ssl http2; server_name katalog.itguys.com.br; # O Certbot vai gerenciar estas linhas # ssl_certificate /etc/letsencrypt/live/katalog.itguys.com.br/fullchain.pem; # ssl_certificate_key /etc/letsencrypt/live/katalog.itguys.com.br/privkey.pem; include /etc/nginx/snippets/global_robots.conf; # Trava de segurança para redes internas include /etc/nginx/conf.d/internal_networks.conf; access_log /var/log/nginx/access.log detailed_proxy; error_log /var/log/nginx/error.log; # --- CABEÇALHOS DE PROXY GLOBAIS --- 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; # --- ESTRATÉGIA DE CACHE HÍBRIDA --- proxy_cache zabbix_cache; # Reutilizando nossa zona de cache existente add_header X-Proxy-Cache $upstream_cache_status; proxy_no_cache 1; # Regra geral: NÃO cachear por padrão proxy_cache_bypass 1; # --- LOCALIZAÇÃO PARA ARQUIVOS ESTÁTICOS (CACHE ATIVADO) --- # Cacheia agressivamente a interface do Snipe-IT (CSS, JS, imagens, etc.) location ~* \.(jpg|jpeg|gif|png|webp|svg|css|js|ico|pdf|woff2|ttf)$ { proxy_no_cache 0; # Ativa o cache apenas para estes arquivos proxy_cache_bypass 0; proxy_cache_valid 200 60m; # Cacheia por 60 minutos # Endereço do seu servidor Snipe-IT. Assumindo que ele roda na porta 80 (HTTP). proxy_pass http://10.10.253.112; } # --- LOCALIZAÇÃO PRINCIPAL (SEM CACHE) --- # Pega todo o resto do tráfego: páginas de ativos, relatórios, APIs, etc. location / { # O cache permanece desativado aqui por herdar da regra geral proxy_pass http://10.10.253.112; } ssl_certificate /etc/letsencrypt/live/katalog.itguys.com.br/fullchain.pem; # managed by Certbot ssl_certificate_key /etc/letsencrypt/live/katalog.itguys.com.br/privkey.pem; # managed by Certbot }