Я использую nginx для обслуживания статических файлов, а также прокси для внутреннего сервера Java. Я использую язык шаблонов на своем бэкэнд-сервере Java, который в конечном итоге заменит все файлы html.
Я не знаю nginx, поэтому я хотел попросить помощи в наиболее эффективном способе сделать это.
Файлы:
/assets // Lots more files in this folder
/index.html
/android-chrome-192x192.png
/android-chrome-512x512.png
/apple-touch-icon.png
/browserconfig.xml
/favicon.ico
/favicon-16x16.ico
/favicon-32x32.ico
/mstile-15x150.png
/safari-pinned-tab.svg
/site.webmanifest
Вот мой файл conf на данный момент. Я обслуживаю статические файлы, но не проксирую:
server {
listen 80 default_server;
listen [::]:80 default_server;
root /root/web;
index index.html;
server_name _;
location /assets/ {
try_files $uri =404;
sendfile on;
sendfile_max_chunk 512k;
}
location / {
try_files $uri =404;
sendfile on;
sendfile_max_chunk 512k;
}
location ~* \.(jpg|jpeg|png|gif|ico|webp|mp4)$ {
expires 30d;
}
location ~* \.(css|js)$ {
expires 10d;
}
gzip on;
gzip_vary on;
gzip_comp_level 4;
gzip_min_length 256;
gzip_proxied any;
gzip_types application/javascript application/json application/x-font-ttf font/opentype image/* text/plain text/css text/xml text/javascript application/x-javascript application/xml;
gzip_disable "MSIE [1-6]\.";
gunzip on;
# error_log /root/nginx-log.txt debug;
}
Мой внутренний сервер будет обслуживать URL-адреса с такими шаблонами:
/basic-url-here // This style will serve html files built with a templating language from the server, so they need to be at the root path
/api/*
Каков правильный/эффективный способ обслуживать все эти файлы с помощью nginx, а также проксировать их на внутренний сервер?