一尘不染

为什么在Glassfish或Tomcat前面使用Apache Web Server?

tomcat

在GF或Tomcat之前使用Apache Webserver是个好主意吗?它会提高性能/安全性吗?

还是没有任何理由将Apache Web Server与GF一起使用?


阅读 295

收藏
2020-06-16

共1个答案

一尘不染

取自https://cwiki.apache.org/confluence/display/TOMCAT/Connectors#Connectors-Q3

  • 聚类。通过使用Apache HTTP作为前端,您可以让Apache HTTP充当通往多个Apache Tomcat实例的内容的大门。如果您的Apache Tomcat之一发生故障,Apache HTTP将忽略它,并且您的Sysadmin可以整夜睡眠。如果您使用硬件负载平衡器和Apache Tomcat的集群功能,则可以忽略这一点。
  • 群集/安全性。您还可以将Apache用作通往不同URL命名空间(/ app1 /,/ app2 /,/ app3 /或虚拟主机)的不同Apache Tomcat的前门。这样就可以将每个Apache Tomcat放在一个受保护的区域中,并且从安全角度来看,您只需要担心Apache HTTP服务器。本质上,Apache成为智能代理服务器。
  • 安全。本主题可以左右摇摆。Java具有安全管理器,而Apache具有更大的意识份额和更多的安全性技巧。我不会更详细地介绍这一点,但让Google成为您的朋友。根据您的方案,一个可能比另一个更好。但也要记住,如果您在Tomcat上运行Apache,则有两个系统需要防御,而没有一个。
  • 附加组件。添加CGI,Perl和PHP对Apache很自然。对于Tomcat而言,它的运行速度较慢,而且更加混乱。Apache HTTP还具有数百个可以随意插入的模块。Apache Tomcat可以具有此功能,但是代码尚未编写。
  • 装饰!通过在Apache Tomcat前面使用Apache HTTP,您可以执行Apache Tomcat不支持或不具有即时代码支持的任意数量的装饰器。例如,可以为Apache Tomcat编写mod_headers,mod_rewrite和mod_alias,但是为什么在Apache HTTP做得很好的情况下重新发明轮子呢?
  • 速度。Apache HTTP在提供静态内容方面比Apache Tomcat更快。但是除非您的网站流量很高,否则这一点是没有用的。但是在某些情况下,Apache Tomcat可能比Apache httpd更快。因此,请对您的网站进行基准测试。使用适当的连接器(启用了sendFile的APR)时,Apache Tomcat可以以httpd速度运行。在Apache httpd和Tomcat之间进行选择时,不应将速度视为一个因素
  • 套接字处理/系统稳定性。就错误情况而言,Apache HTTP的套接字处理比Apache Tomcat更好。主要原因是Apache Tomcat必须通过需要跨平台的JVM执行所有套接字处理。问题是套接字优化是特定于平台的难题。大多数情况下,Java代码都很好,但是当您同时受到连接断开,无效数据包,来自无效IP的无效请求的轰炸时,与基于JVM的程序相比,Apache HTTP在删除这些错误情况方面做得更好。(YMMV)
2020-06-16