- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道将 Tomcat 同时作为 Web 服务器和容器运行是否可以?另一方面,似乎扩展 Web 应用程序的正确方法是使用监听端口 80 的 Apache HTTP 并将其连接到监听另一个端口的 Tomcat?两种方式都可以接受吗?现在用的是什么?主要区别是什么?大多数主要网站是如何做到这一点的?
谢谢。
最佳答案
出于多种原因,将 Apache(或任何其他网络服务器)置于您的应用程序服务器 (Tomcat) 之前是一件好事。
首先要考虑的是静态资源和缓存。
Tomcat 可能还会提供大量静态内容,甚至在动态内容上它会向浏览器发送一些缓存指令。但是,每一个第一次访问你的tomcat的浏览器都会导致tomcat发送静态文件。因为在 Tomcat 中处理一个请求比在 Apache 中要贵一些(因为 Apache 被 super 优化并且利用了 Tomcat 中并不总是可用的非常低级的东西,因为 Tomcat 从请求中提取的信息比 Apache 需要的多得多等等。 ..),静态文件由 Apache 作为服务器可能更好。
然而,由于配置 Apache 提供部分内容而 Tomcat 提供其余内容或 URL 空间是一项艰巨的任务,因此通常更容易让 Tomcat 使用正确的缓存 header 提供所有内容,而 Apache 在它前面捕获内容,将其提供给需要的浏览器,并对其进行缓存,以便其他浏览器点击同一文件将直接从 Apache 提供服务,甚至不会干扰 Tomcat。
除了静态文件,还有很多动态的东西可能不需要每毫秒更新一次。例如,主页加载的 json 告诉用户你的数据库中有多少东西,这是一个执行数千次的昂贵查询,可以安全地每小时执行一次左右,而不会激怒你的用户。因此,tomcat 可以使用适当的一小时缓存指令为 json 提供服务,Apache 将缓存 json 片段并将其提供给任何需要它的浏览器一小时。显然还有很多其他方法可以实现它(缓存过滤器、缓存查询的 JPA 缓存等...),但是发送正确的缓存 header 并使用 Apache 作为反向代理非常简单,符合 REST 标准并且可以很好地扩展.
另一个考虑因素是负载平衡。 Apache 带有一个很好的负载平衡模块,可以帮助您在多个 Tomcat 实例上扩展您的应用程序,假设您的应用程序可以水平扩展或在集群上运行。
第三个考虑因素是关于 ulrs、 header 等。有时您可能需要更改一些 url,或者删除或覆盖一些 header 。例如,在重大更新之前,您可能希望在浏览器上禁用缓存几个小时以避免浏览器继续使用陈旧数据(与在切换服务器之前降低 DNS TTL 相同),或者将旧应用程序移动到另一个 url 空间,或者重写旧的尽可能使用新的 URL。虽然可以在 web.xml 文件中重新配置 servlet,并且过滤器可以创造奇迹,但如果您使用的是解释 URL 的框架,则可能需要对站点地图文件或类似内容做大量工作。
在 Tomcat 前面安装 Apache 或其他 Web 服务器可能有助于仅使用 mod_rewrite 等模块更改 Apache 配置文件。
所以,我总是建议在 Tomcat 之前安装 Apache httpd。由于资源缓存,连接处理上的小开销通常可以恢复,并且在您第一次需要移动 URL 或处理某些 header 时重新进行额外的配置工作。
关于apache - 我应该单独运行 Tomcat 还是 Apache + Tomcat?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12343187/
我希望在某些环境中使用用户名和密码保护某个角色,但在其他环境中甚至不需要提示。如果我在 tomcat web.xml 中有一个 auth-constraint,我可以创建一个具有“匿名”访问权限的角色
我正在使用 Tomcat jmxproxy 和状态来监视 Web 应用程序,但是 jmxproxy 页面中有很多无用的信息,并且其中没有任何信息,例如事件连接数。有谁知道如何过滤 jmxproxy 页
是否可以通过执行 JSP 来重启 Tomcat6? 这是因为我想通过使用网络服务器远程部署应用程序的更改。 部署脚本是用 bash 编写的,它从 svn 中 check out 最新版本,然后将其打包
我有一个包含 2 个子项目(后端和 ui)的 gradle 项目。 Ui由gradle tomcatRunWar完美启动.后端有我们在生产地点的配置描述符/conf/Catalina/localhos
发现 XAMPP 控件认为 tomcat 正在运行但无法停止它的问题。 在catalina下的tomcat logs目录下可以找到如下错误 “严重:无法联系 localhost:8005。Tomcat
PuppetLabs 在 PuppetForge 上有一个模块,用于部署 Tomcat 及其配置。 https://forge.puppet.com/puppetlabs/tomcat Tomcat
我有一个部署到 Tomcat 实例中的 Web 应用程序。我希望能够将 tomcat 配置为在 Tomcat 本身启动时不自动启动该应用程序。但是,我确实希望启动 Tomcat 管理器,以便我可以根据
操作系统:windows XP。 我已经安装了 Tomcat 7.0.25,文件夹“manager”位于 webapps 文件夹中。 我已阅读此处的文档:http://tomcat.apache.or
我们在 server.xml 文件中启用了以下访问日志模式 pattern="%h %H %l %u %t "%r" %s %b location: %{location}o"。 有人可以帮助理解模式
我最近开始使用 tomcat,我有一个关于 Tomcat 请求路由/映射的查询。 假设我在 tomcat 服务器中部署了四个应用程序 A、B、C 和 D,当有请求到来时,tomcat 如何知道要调用哪
我在我的计算机上使用 Tomcat,它可以通过端口 8080 访问。我想要的是我应该能够使用我的计算机的 IP 地址访问我的 Tomcat 服务器页面。我以前读过很多主题,但找不到一个可以帮助我的主题
我有一个 tomcat 7 服务器和一个 postgreSQL 9.0 数据库。我用它来为地理网络元数据编辑器设置开发环境。一切都是根据 geonetwork 网站教程设置的。我在将服务器与数据库连接
我的服务器有 物理 ip 和 虚拟 ip 由网络管理员设置。在我安装的服务器内部 Apache tomcat 7.0.29并创建一个网络应用程序。当我运行 wget http://:8080/xxx或
我有多个应用程序在不同的端口上运行(tomcat 实例) 都有相同的CATALINA_HOME 目前我必须在所有实例中部署和安装psi 探针,并在不同的窗口中分别监控每个端口。 我如何在一个单一的探测
based on this question 我尝试将 Tomcat 控制台输出重定向到一个文本文件,它对我的 Web 应用程序工作正常,但问题是,每次 Tomcat 启动时它都会被覆盖。我需要创
我需要阐明我的问题。问题是:有什么方法可以影响 Tomcat 为特定部署的应用程序分配多少堆内存?更多详细信息 - 我如何为已部署的应用程序设置特定的 Java 选项(考虑我想为每个应用程序设置特殊的
应用服务器内部的类加载机制是开发人员常见的困惑来源;这就是为什么我想问一个关于 tomcat 7 服务器中这个机制的问题:我有一个网络应用程序 sample.war,它依赖于 jgroups 库, 放
尝试将嵌入式 Tomcat 5 迁移到嵌入式 Tomcat 7。在启动过程中获取 NPE。 我扩展了 Embedded 类并按照正确的顺序执行所有建议的初始化。 NPE 发生在这里: Caused b
我可以使用随附的 start.sh 文件启动 tomcat,但是是否有任何参数可以用来执行以下操作: 在指定的根目录启动 Tomcat 服务 强制 Tomcat 在浏览器中拉出指定的主页 谢谢 最佳答
我在两台 diff 机器 tomcat 服务器上做一个简单的集群配置。每次我启动 tomcat 时,我都会收到一个错误,就像集群组中没有事件成员一样。我正在附加集群配置
我是一名优秀的程序员,十分优秀!