介绍
Apache2.2 本身拥有如mod_proxy这样一系列优秀的模块,它们拥有一部分和mod_jk一样的功能(AJP Protocol),也能整合实现负载均衡。
AJP (Apache Jserv Protocol) 当前版本是1.3,是一个持久性的二进制协议。持久性指web server 和application server 直接的连接一旦建立,在系统生命周期内一直保持open的状态。
从客户端看,web server 和application server本质上是一个单一的系统。
既然系统中的某个节点可能因为各种原因死掉,同application server 一样,mod_proxy和mod_jk需要能够发现各种连接和通道的错误并作出反应。
mod_jk在过去几年就已经拥有了这样的技术优势,现在有各种技术实现连接错误侦察和修复。从现在来看,mod_jk在这方面比mod_proxy有更多的优势。
协议
mod_jk是基于AJP协议的,这个协议也通常被认为是二进制http协议。基于二进制协议,主要考虑有两点,首先,客户请求信息已经在web server被解码,就不用再把完整的请求数据发送给application server了;其次,在web server 和 application server 之间,请求和返回 header信息不再是string形式,而是两字节序列的原子形式,这样也就降低了网络带宽要求。
但是,AJP协议有一个主要的限制,就是packet的大小不能超过8K。最新的mod_jk和Tomcat使得这个限制可以加大到64K,但是还是有限制。mod_proxy也有限制,最大的packet大小是8K.如果遇到较大的客户端请求就会出问题了,特别像有些客户SSO模块存储了大量的session信息在cookies和header中。如果在要支持大型客户端请求,唯一的解决方案是使用AJP http协议。
加密以及SSL支持
AJP协议没有加密,不能够用在开放外部网络环境中。在这样的环境中,web server和application server 直接的的通信可能会被监听,需要使用一定的SSL隧道技术保障数据安全。另外一个选择是使用https协议结合mod_proxy.但是https会稍微复杂一点,需要在application server中添加filter处理客户端传递过来的证书。AJP协议则会自动处理,它将加密数据通过序列的方式再web server 和application
server直接传递。可以说,AJP协议的行为像是一个缓存SSL的加速器(the AJP protocol behaves like caching SSL accelerator)。
这样的性能更高效,因为数据只需进行一次解密。但是使用不同的网卡进行通信、建设防火墙和路由才是保障web server和application server之间通信安全最好的解决方案。
另外有些观点认为,将web server 和application server 放置在同一台物理机器上,他们直接通过内存进行通信,这样可以加强整个系统的安全性。
负载均衡
最新的mod_jk比mod_proxy_balancer有更多的优势特性。mod_jk额外拥有一些“商业特性”方法,可以根据实际application server 反应时间设置负载均衡。
mod_jk的“负责均衡维护”(load balancer maintenance)功能,能够有效的处理突发爆炸性的请求;当一个节点在维护的时候,能够减少降低此间的的请求。这种情况需要大量的application server和session replication(会话复制)。
mod_jk的Domain Model Clustering功能,支持最新Jboss Cache的buddy replication。它通过将集群中的节点进行分组来降低session replication 数据传输,而且replication动作只需在集群中的(相邻的)节点之间进行。
Apache httpd 各个版本
新版mod_proxy只支持Apache httpd 2.2和更高版本,也就是说,如果web server升级需要同时升级新版的mod_proxy.
Apache httpd可以结合worker-mpm使用。使用worker mpm的时候,mod_proxy和mod_jk都有设置web和application server之间连接池大小的选项。这个选项在部署的时候很有必要,可以使用Apache httpd 在application server之前传送一些其他内容,例如传送递静态内容等。在这种情况下,时间发送到application server的请求比实际上web server接收到的客户端请求要少很多,它允许worker mpm的链接池大小设置比MaxThreadsPerChild更小。
Windows和Netware版本的Apache httpd是完全线程的,所有他们的mpm和连接池大小可以设置处理更大的范围。
mod_proxy vs. mod_jk
那么什么时候使用哪一个呢?这依赖于你的架构。如果你已经有了或者需要apache 2.2的功能,那么你可以再mod_proxy和mod_jk直接选择。mod_jk在apache2.2上允许得很好。关键看你需要什么样的功能:
mod_proxy
- 优势:
- 不需要编译和维护一个对立的模块。mod_proxy,mod_proxy_http,mod_proxy_ajp,mod_proxy_balancer已经是apache 2.2+的标准集成部分;
- 可以使用http、https和AJP协议,即便是在同一个balancer中。
- 劣势:
- mod_proxy_ajp不支持大于8k的数据包;
- 只有最基本的负载均衡器;
- 不支持域模型集群(domain model clustering)
mod_jk
- 优势:
- 先进的负载均衡器;
- 先进的节点失败侦察功能;
- 支持大型AJP 数据包
- 劣势:
- 需要单独维护一个独立的模块;
总结
我个人建议是如果有能力维护mod_jk模块的二进制版本,尽量使用mod_jk。mod_proxy一直在更新但还缺少一些mod_jk的功能。但是,如果你需要https和一个简单的负载均衡就是用mod_proxy.
http://www.ibm.com/developerworks/cn/opensource/os-lo-apache-tomcat/
http://502245466.blog.51cto.com/7559397/1304050
http://my.oschina.net/heartdong/blog/98416
相关推荐
window下完整的apache+mod_jk或mod_proxy+tomcat配置方案,用于负载均衡及动静态页面分离。里面包含有相对应版本的apache、tomcat、mod_jk,已经多个参考文档
`mod_jk.so`是Apache的一个模块,它用于连接Apache与Tomcat应用服务器,实现负载均衡和应用级代理,这对于运行Java Web应用程序的环境至关重要。在CentOS 6.5-6.9系统上编译安装Apache 2.4并添加mod_jk.so模块的步骤...
`mod_jk.so`是Apache HTTP服务器的一个模块,它实现了阿帕奇与Tomcat之间的通信协议——JK(Java Keteen)协议。这个模块使得Apache能够识别并转发特定的URL到Tomcat进行处理,从而实现负载均衡和故障切换等功能。在...
在Java企业级应用中,Apache常作为前端服务器,通过`mod_jk`模块与后端的Tomcat进行通信,实现动态内容的处理。这里我们详细讨论`mod_jk.so`以及在64位Linux环境中的配置和使用。 `mod_jk.so`是Apache的负载均衡器...
将以下Module的注释去掉,这里并没有使用mod_jk.so进行apache和tomcat的链接,从2.X以后apache自身已集成了mod_jk.so的功能。只需简单的把下面几行去掉注释,就相当于以前用mod_jk.so比较繁琐的配置了。这里主要采用...
Apache与mod_jk协同工作,负责根据预设策略将请求分发到各个JBoss实例,实现负载均衡。 **二、安装与启动** Apache的安装通常是直接解压缩,遇到启动问题时,可尝试通过命令行启动Apache(如Apache.exe或httpd.exe...
mod_jk是一种被广泛使用的技术,它通过JK插件与Tomcat进行集成,实现集群中各个实例的负载均衡。mod_proxy则是Apache HTTP Server的另一个模块,它也可以用于实现负载均衡,但它和mod_jk的工作原理有所不同。 在...
4. 配置`mod_proxy`和`mod_proxy_ajp`:虽然`mod_jk`是常用的Apache-Tomcat连接器,但也可以选择使用`mod_proxy`和`mod_proxy_ajp`组合。`mod_proxy`负责代理功能,而`mod_proxy_ajp`则用于与Tomcat的AJP协议交互。 ...
本文将深入讲解如何配置Apache2.4以实现对Tomcat7.0.73的负载均衡和session共享复制,同时探讨mod_proxy和mod_jk两种代理方式。 首先,Apache2.4是HTTP服务器,负责处理客户端的HTTP请求,而Tomcat7.0.73是Java应用...
JK模块是Apache与Tomcat之间的桥梁,实现了Apache的 mod_proxy_ajp 和 mod_jk 两种方式来与Tomcat通信。JK模块通过AJP(Apache JServ Protocol)协议与Tomcat交互,将HTTP请求转发到后端的Tomcat实例上。这种分发...
最后,通过`workers.properties`(如果是mod_jk)或Apache的配置文件(如果是mod_proxy_ajp)设定Apache与Tomcat之间的通信规则。 在部署完成后,测试集成是至关重要的,确保静态内容由Apache正确服务,动态内容被...
在实际环境中,JK模块还可以结合其他组件,如Apache的mod_proxy_ajp模块,实现更高级的负载均衡策略,比如轮询、最少连接数等,以优化多台Tomcat服务器之间的负载分配。 总之,"apache_2.2.4-win32-x86-no_ssl.msi...
Apache的mod_jk模块是Apache与Tomcat之间的常用连接桥梁。它实现了JK(Java Kona)协议,负责将HTTP请求转发到Tomcat实例,同时将响应返回给客户端。通过配置mod_jk的worker.properties文件来定义Tomcat实例,以及...
mod_jk.conf是mod_jk模块的配置文件,定义了如何与Tomcat服务器交互。主要设置有: - `JkWorkersFile`:指定workers.properties文件的位置,该文件包含了Tomcat服务器的详细信息。 - `JkMount`:定义哪些URL路径...
mod_jk提供了一个JK工作线程,用于处理与Tomcat之间的通信,支持AJP协议,能更高效地传输数据。 3. **Tomcat集群配置**:在Tomcat中,通过共享session数据和复制应用状态,可以创建一个集群。每个Tomcat实例都需要...
本文介绍了使用Apache反向代理配置集群,基于mod_proxy+Apache 2.2.16+Tomcat 7实现负载均衡与集群配置。 一、 背景简介 大多数企业应用都希望能做到7*24小时不间断运行。要保持如此高的可用性并非易事,比较常见...
Apache的负载均衡模块主要有两种常用的方式:mod_proxy和mod_jk。mod_proxy是Apache内建的反向代理模块,可以直接处理HTTP、HTTPS等协议,支持轮询、最少连接、IP哈希等多种负载均衡策略。mod_jk是专门为Tomcat设计...
集成Apache和Tomcat主要有两种常见的方法:通过Apache的模块(如mod_jk或mod_proxy)或者使用Nginx作为反向代理。这里我们将重点讨论使用Apache的mod_jk模块进行集成。 1. **安装Apache和Tomcat** - 首先,你需要...
mod_jk 和 mod_proxy 不同,mod_cluster 利用应用服务器节点和反向代理之间的附加连接将服务器端负载平衡因素和生命周期事件传输回代理。 这个额外的反馈通道允许 mod_cluster 提供其他负载平衡解决方案中没有的智能...