У меня есть EC2 ubuntu с настройкой Glassfish v3 + Nginx для размещения моего веб-приложения java. Это приложение развертывается в Glassfish в виде файла WAR. NGINX в настоящее время передает все запросы на сервер приложений glasshfish, включая запросы для статических изображений, css и т. Д., Javascripts и т. Д.
server {
listen 80;
server_name whatever.com www.whatever.com;
access_log /var/log/nginx/whatever.com.access.log;
location / {
proxy_pass http://127.0.0.1:8080/javapp/;
proxy_pass_header Set-Cookie;
proxy_pass_header X-Forwarded-For;
proxy_pass_header Host;
}
}
Я решил это следующим образом: а) Измените файл конфигурации следующим образом
server {
listen 80; ## listen for ipv4
server_name www.whatever.com; ## change this to your own domain name
root /home/ubuntu/www/public_html;
## Only requests to our Host are allowed i.e. nixcraft.in, images.nixcraft.in and www.nixcraft.in
if ($host !~ ^(www.whatever.com)$ ) {
return 444;
}
location ~* \.(jpg|jpeg|gif|css|png|js|ico)$ {
access_log off;
expires max;
}
location / {
access_log off;
proxy_pass http://localhost:8080;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /var/www/nginx-default;
}
}
б) в корневом каталоге Nginx HTML (/ home / ubuntu / www / public_html) создайте подкаталог с тем же именем, что и контекст вашего веб-приложения. например если ваш URL-адрес webpp - www.whatever.com/mycoolapp, создайте каталог с именем / home / ubuntu / www / public_html / mycoolapp
в) разархивируйте файл войны в эту папку. Избавьтесь от папки WEB-INF
г) перезапустите nginx. Для проверки остановите свое веб-приложение, не отключая NGINX, и получите доступ к изображению или CSS из своего веб-приложения.