Назад | Перейти на главную страницу

Как настроить Glassfish + NGINX для обслуживания статических файлов с NGINX?

У меня есть 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 из своего веб-приложения.