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

Запуск программы sinatra [Kibana] за обратным прокси nginx в веб-каталоге

Я пытаюсь заставить Kibana работать за nginx в определенном веб-каталоге. Или, другими словами, я пытаюсь использовать обратный прокси-сервер nginx http://example.com/kibana к http://localhost:5601/, где запущено приложение Kibana sinatra.

Я запустил Kibana с помощью сценария инициализации, и если я curl в localhost url с сервера, я получаю ожидаемый ответ. Однако переход к http://example.com/kibana/ дает мне сообщение Sinatra doesn’t know this ditty. и предположение, что /kibana/ должен что-то делать. Предположительно, это проблема маршрутизации.

Моя конфигурация nginx проста:

server {                                                                                                                                                       
    listen   80; ## listen for ipv4; this line is default and implied                                                                                          
    listen   [::]:80 default ipv6only=on; ## listen for ipv6                                                                                                   

    root /var/www;                                                                                                                                             
    index index.html index.htm;                                                                                                                                

    # Make site accessible from http://localhost/                                                                                                              
    server_name _;                                                                                                                                             

    location / {                                                                                                                                               
        # First attempt to serve request as file, then                                                                                                         
        # as directory, then fall back to index.html                                                                                                           
        try_files $uri $uri/ /index.html;                                                                                                                      
        # Uncomment to enable naxsi on this location                                                                                                           
        # include /etc/nginx/naxsi.rules                                                                                                                       
    }                                                                                                                                                          
    location /kibana/ {                                                                                                                                     
        proxy_pass  http://localhost:5601;                                                                                                                     
        proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;                                                                  
        proxy_redirect off;                                                                                                                                    
        proxy_buffering off;                                                                                                                                   
        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_pass      http://127.0.0.1:5601;

Заменить на

proxy_pass      http://127.0.0.1:5601/;

попробуй это: https://serverfault.com/a/379679/82682 (со временем замените '/foo/Kibana-0.2.0')

location /kibana {
    # rewrite before passing to proxy
    rewrite /kibana/(.*) /$1  break;
    proxy_pass      http://127.0.0.1:5601;
    # include nginx' proxy-defaults
    include proxy_params;

    # serve static stuff directly from the static-directory
    location /kibana/favicon.ico {
        alias /foo/Kibana-0.2.0/static/favicon.ico;
    }
    location /kibana/images {
        alias /foo/Kibana-0.2.0/static/images;
    }
    location /kibana/lib {
        alias /foo/Kibana-0.2.0/static/lib;
    }
}