简体   繁体   English

Nginx 将路径重定向到另一个本地主机应用程序

[英]Nginx redirect a path to another localhost app

Is it possible in nginx to have path /phoenix , map to localhost:9090 ? nginx 中是否有可能有路径/phoenix , map 到localhost:9090

My webapp doesnt' have /phoenix route inside, so when a user goes to domain.tld/phoenix it'll go to localhost:9090 and not localhost:9090/phoenix .我的 webapp 内部没有/phoenix路由,因此当用户访问domain.tld/phoenix时,它将 go 到localhost:9090而不是localhost:9090/phoenix

upstream phoenix {
  server localhost:9090;
}

upstream homepage {
  server localhost:9191;
}

server {
  listen 80;
  listen [::]:80;

  server_name domain.tld;
  return 404;
}

server {
  listen 443 ssl http2 default_server;
  listen [::]:443 ssl http2 default_server;

  server_name domain.tld;

  ssl_certificate /etc/letsencrypt/live/domain.tld/fullchain.pem;
  ssl_certificate_key /etc/letsencrypt/live/domain.tld/privkey.pem;
  ssl_trusted_certificate /etc/letsencrypt/live/domain.tld/chain.pem;
  include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
  ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

  ssl_ecdh_curve secp384r1;
  ssl_session_cache shared:SSL:10m;
  ssl_stapling on;
  ssl_stapling_verify on;

  add_header Strict-Transport-Security "max-age=63072000; includeSubdomains";
  add_header X-Frame-Options DENY;
  add_header X-Content-Type-Options nosniff;

  location / {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_pass http://homepage;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
}

  location /phoenix {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_pass http://phoenix;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";

    # asset delivery
    location ~* ^.+\.(css|cur|gif|gz|ico|jpg|jpeg|js|png|svg|woff|woff2)$ {
      root /home/user/app/priv/static;
      etag off;
      expires max;
      add_header Cache-Control public;
    }
  }
}

@RichardSmith thank you. @RichardSmith 谢谢。 So we do need the slash at the end.所以我们确实需要最后的斜线。

proxy_pass http://phoenix/;

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM