gpt4 book ai didi

linux - 不用端口号访问tomcat中的Web应用程序

转载 作者:太空宇宙 更新时间:2023-11-04 12:43:59 24 4
gpt4 key购买 nike

我正在尝试在 Linux 服务器上拥有多个 tomcat 实例,每个实例都会在其中部署一个 Web 应用程序 ROOT。

在访问应用程序时,url 的格式为 : 而我不希望最终用户记住应用程序的 ip 地址或端口。

由于在 linux 服务器中会使用多个实例,默认为 80 端口 ( http ) 和 443 ( https ) 将无济于事。

我的想法是公开应用程序的 DNS 名称,看起来 Apache HTTP 服务器可以帮助我解决这个问题。方法对吗?

我假设 apache 服务器应该是每个 linux 服务器一个而不是每个 tomcat 实例一个。这可以确认吗?

Apache Tomcat 版本为 8.5.4,计划与 apache http 服务器版本一起使用 2.4

最佳答案

将 Apache HTTPD(或任何其他)设置为前端服务器是一种很好的方法。

您将无法在每个服务器上使用多个 Apache HTTPD,因为您不想在 url 中使用 :port 符号,至少在更多服务器中将无法使用标准 HTTP/HTTPS 端口在同一台服务器上一次超过一个 HTTPD。

如果您打算同时使用 http 和 https,您应该至少为它们各自创建一个虚拟主机。使用 SSL 443 端口为基于名称的虚拟主机创建虚拟主机时存在限制,因此如果您希望启用多个 HTTPS 端口,则需要基于 IP 的虚拟主机。

This is the Apache HTTPD 2.4 virtual host documentation .

然后,您可以使用 mod_proxy 将请求转发给每个 Tomcat或 tomcat connector .我个人根据当前需求选择一个或另一个,特别是如果 Tomcat 和 Apache HTTPD 中的上下文之间存在直接对应关系(在这种情况下我使用 AJP)或者需要重写它(mod_rewrite):

httpd://apache.httpd/context1 -> tomcat:XXXX/context1 (ajp tomcat connector)

httpd://apache.httpd/ -> tomcat:XXXX/context2 (mod_rewrite)

httpd://apache.httpd/context3 -> tomcat:XXXX/context4 (mod_rewrite)

关于linux - 不用端口号访问tomcat中的Web应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39345199/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com