NginxのProxyでリクエストパスを基準としたマルチテナントを実現したいと考えております。
今まではサブドメインを用いたマルチテナントを実現していたのですが、SSL証明書取得のコストの関係上、一つのドメインでパスを変更して接続先のアプリを変更したいのです。
Nginx
1upstream multiTenant1 { 2 server 127.0.0.1:8080; 3} 4 5server { 6 listen 443; 7 server_name xxxx.jp; 8 9 location /yyy/ { 10 proxy_pass http://multiTenant1/; 11 proxy_http_version 1.1; 12 proxy_set_header Upgrade $http_upgrade; 13 proxy_set_header Connection "upgrade"; 14 proxy_set_header Host $http_host; 15 16 proxy_set_header X-Real-IP $remote_addr; 17 proxy_set_header X-Forward-For $proxy_add_x_forwarded_for; 18 proxy_set_header X-Forward-Proto http; 19 proxy_set_header X-Nginx-Proxy true; 20 21 proxy_redirect off; 22 } 23}
configは以上のようになっています。
Host名を変更すればよいのかと、上記のproxy_set_header Hostの部分をhttps://xxx.jp/yyy/や$http_host$request_uri;等に変更を試してみましたが、変わらずxxx.jp/リソースパスに要求を投げてしまっていました。
WebAppにホスト名をhttps://xxx.jp/yyy/と認識させるようなconfigの描き方はありますか?
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。