關於nginx代理訪問配置uri依然報404的問題


這里是一個nginx反代到kibana的一個配置。網上大多數在nginx的配置文件里面直接在根下配置了反代kibana,如下所示:

upstream kibana_server {
        server  127.0.0.1:5601 weight=1 max_fails=3  fail_timeout=60;
}

server {
        listen 80;
        server_name 192.168.10.142;
        auth_basic "Restricted Access";
        auth_basic_user_file /etc/nginx/httppass.txt;  
        location / {
        proxy_pass http://kibana_server;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
        }
}

不過有時候為了方便處理uri,可能不會直接像上面這樣放在根下,而是這樣的。

location /kibana {
        proxy_pass http://kibana_server;
        proxy_http_version 1.1;
        xxxxx
}

這個在訪問的時候是會出現問題的,部分的kibana的組件找不到里面的圖片或其他的css組件。比如:

所以我們可以這樣子來做:

location /kibana/{
    proxy_pass http://kibana_host/;
    rewrite ^/kibabna/(.*)$ /$1 break;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header Host $host:$server_port;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_http_version 1.1;
  }

然后kibana也需要改一下配置文件
server.basePath: "/kibana"
這樣子就可以了


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM