首页 > 解决方案 > Apache代理不同的上下文路径cookie问题

问题描述

我目前正在开发一个将部署在 Docker 容器中的应用程序。Docker 包含一个 Tomcat,它以 ROOT.war 的形式运行应用程序,因此位于顶层。

这个想法是,当我们的用户运行容器时,他们可能希望在各自服务器上的特定上下文路径上运行多个副本,例如:

https://somedomain.com/ahttps://somedomain.com/b

我的计划是简单地告诉他们像这样配置反向代理:

ProxyPreserveHost On
RewriteEngine On

# Map https://somedomain/a to http://internalserver:9001
RewriteRule     ^/a$ /a/ [R]
ProxyPass        /a/ http://internalserver:9001/
ProxyPassReverse /a/ http://internalserver:9001/

# Map https://somedomain/b to http://internalserver:9002
RewriteRule     ^/b$ /b/ [R]
ProxyPass        /b/ http://internalserver:9002/
ProxyPassReverse /b/ http://internalserver:9002/

其中 9001 和 9002 是运行我的应用程序副本的两个 Docker 容器的端口。

现在,这使应用程序运行,但 cookie 存在问题,因为 Tomcat 中服务器上的上下文路径始终为空,因此存在会话问题。

我见过几个关于类似情况的问题,但在所有情况下,人们都可以更改公共路径或 Tomcat 中的路径以使它们匹配。就我而言,我根本无法做到这一点,因为我将规定我们软件的用户必须使用哪条路径。

以下是此类问题的示例:

https://serverfault.com/questions/311994/how-to-proxy-context-to-different-backend-context-in-apache https://serverfault.com/questions/495017/how-do-i-ensure -the-context-path-is-the-same-when-accessing-a-web-app-via-apache Tomcat 在路径上的 apache 代理错误后面


有什么方法可以使这个设置正常工作吗?

我可以更改代理配置以某种方式转发上下文路径吗?

还有其他选择吗?

标签: apachedockertomcatreverse-proxycontextpath

解决方案


好的,我找到了一个非常简单的解决方案。也许它会帮助别人,所以我会在这里发布:

我发现有一个名为的代理配置选项ProxyPassReverseCookiePath旨在用于我想要实现的目标,所以我将配置更改为:

RewriteRule      ^/a$ /a/ [R]
<Location /a/>
  ProxyPass        http://internalserver:9001/
  ProxyPassReverse http://internalserver:9001/
  ProxyPassReverseCookiePath / /a
</Location>
RewriteRule      ^/b$ /b/ [R]

<Location /b/>
  ProxyPass        http://internalserver:9002/
  ProxyPassReverse http://internalserver:9002/
  ProxyPassReverseCookiePath / /b
</Location>

这会将来自内部服务器的每个 cookie 路径映射//a/b取决于应用程序的路径,这正是我想要的。/如果没有可用的上下文路径,应用程序本身现在总是将 cookie 路径设置为。然后反向代理将其映射回请求它的任何位置。


推荐阅读