5

我想要做的是采取以下措施:

http://localhost:10000
http://localhost:11000
http://localhost:12000

并将它们分别路由如下:

http://my-app (this is port 10000 traffic)
http://my-app/app  (this is port 11000 traffic)
http://my-app/blog (this is port 12000 traffic)

这是我的 conf.d 文件-

<VirtualHost *:80>
  ServerName my-app.domain.com
  ServerAlias my-app

  Redirect / https://my-app.domain.com/
</VirtualHost>

<VirtualHost *:443>
  ServerName my-app.domain.com
  ServerAlias my-app

  Include ssl/default/ssl.cfg

  RewriteEngine On
  ProxyRequests Off
  ProxyPreserveHost On
  RemoteIPHeader X-Forwarded-For
  RequestHeader set X-FORWARDED-SSL on
  RequestHeader set X-FORWARDED_PROTO https


  ProxyTimeout 900
  TimeOut 900

  RewriteRule ^$ / [R]

  ProxyPass / http://localhost:10000/
  ProxyPassReverse / http://localhost:10000/

  RewriteRule ^/app/(.*) http://localhost:11000/$1 [P,L]
  ProxyPassReverse /app/ http://localhost:11000

</VirtualHost>

重定向适用于初始端口,但不适用于前往端口 11000 的流量。我确定我在做一些愚蠢的事情,但我不知道是什么。

4

1 回答 1

9

使用proxypass时需要先指定最“具体”的路径,先指定/blog//app/再指定/。如果你不这样做,ProxyPAss / 将覆盖其他人。

RewriteRule ^$ / [R]<-- 没有发生,因为在虚拟主机中只有 ^/$ 将匹配并且 ^/$ 已经是 /,所以它不起作用,如果它这样做它会循环。

另外,不要使用 mod_rewrite 因为不需要使用它进行代理,或者至少您没有做任何 proxypass 或 proxypassmatch 不会单独做的事情,并且在使用 ProxyPass 时匹配斜杠(如果源添加中有一个结束斜杠在目标中,如果没有,则不要,否则后端的响应可能会发生意外行为),并且如前所述,首先指定最具体的路径:

因此,完全删除 mod_rewrite 指令并且:

ProxyPass /app/ http://localhost:11000/
ProxyPassReverse /app/ http://localhost:11000/

ProxyPass /blog/ http://localhost:12000/
ProxyPassReverse /blog/ http://localhost:12000/

ProxyPass / http://localhost:10000/
ProxyPassReverse / http://localhost:10000/
于 2016-12-30T10:33:30.933 回答