`

apache+tomcat Tomcat Port 8009 与AJP13协议

阅读更多

Tomcat最主要的功能是提供Servlet/JSP容器,尽管它也可以作为独立的Java Web服务器,它在对静态资源(如HTML文件或图像文件)的处理速度,以及提供的Web服务器管理功能方面都不如其他专业的HTTP服务器,如IIS和Apache服务器。
  
  因此在实际应用中,常常把Tomcat与其他HTTP服务器集成。对于不支持Servlet/JSP的HTTP服务器,可以通过Tomcat服务器来运行Servlet/JSP组件。
  
  当Tomcat与其他HTTP服务器集成时,Tomcat服务器的工作模式通常为进程外的Servlet容器,Tomcat服务器与其他HTTP服务器之间通过专门的插件来通信。关于Tomcat服务器的工作模式的概念可以参考本书1.4节。
  
  本章首先讨论Tomcat与HTTP服务器集成的一般原理,然后介绍Tomcat与Apache以及IIS集成的详细步骤。
  
  22.1 Tomcat与HTTP服务器集成的原理
  
  Tomcat服务器通过Connector连接器组件与客户程序建立连接,Connector组件负责接收客户的请求,以及把Tomcat服务器的响应结果发送给客户。默认情况下,Tomcat在server.xml中配置了两种连接器:
  
  <!-- Define a non-SSL Coyote HTTP/1.1
  Connector on port 8080 -->
  <Connector port="8080"
  maxThreads="150"
  minSpareThreads="25"
  maxSpareThreads="75"
  enableLookups="false"
  redirectPort="8443"
  acceptCount="100"
  debug="0"
  connectionTimeout="20000"
  disableUploadTimeout="true" />
  
  <!-- Define a Coyote/JK2 AJP 1.3
  Connector on port 8009 -->
  <Connector port="8009"
  enableLookups="false"
  redirectPort="8443" debug="0"
  protocol="AJP/1.3" />
  
  第一个连接器监听8080端口,负责建立HTTP连接。在通过浏览器访问Tomcat服务器的Web应用时,使用的就是这个连接器。
  
  第二个连接器监听8009端口,负责和其他的HTTP服务器建立连接。在把Tomcat与其他HTTP服务器集成时,就需要用到这个连接器。
  
  Web客户访问Tomcat服务器上JSP组件的两种方式如图22-1所示。

  

 图22-1 Web客户访问Tomcat服务器上的JSP组件的两种方式
  
   在图22-1中,Web客户1直接访问Tomcat服务器上的JSP组件,他访问的URL为http://localhost:8080 /index.jsp。Web客户2通过HTTP服务器访问Tomcat服务器上的JSP组件。假定HTTP服务器使用的HTTP端口为默认的80端口, 那么Web客户2访问的URL为http://localhost:80/index.jsp 或者 http://localhost/index.jsp。
  
  下面,介绍Tomcat与HTTP服务器之间是如何通信的。
  
  22.1.1 JK插件
  
   Tomcat提供了专门的JK插件来负责Tomcat和HTTP服务器的通信。应该把JK插件安置在对方的HTTP服务器上。当HTTP服务器接收到客 户请求时,它会通过JK插件来过滤URL,JK插件根据预先配置好的URL映射信息,决定是否要把客户请求转发给Tomcat服务器处理。
  
   假定在预先配置好的URL映射信息中,所有"/*.jsp"形式的URL都由Tomcat服务器来处理,那么在图22-1的例子中,JK插件将把客户请 求转发给Tomcat服务器,Tomcat服务器于是运行index.jsp,然后把响应结果传给HTTP服务器,HTTP服务器再把响应结果传给Web 客户2。
  
  对于不同的HTTP服务器,Tomcat提供了不同的JK插件的实现模块。本章将用到以下JK插件:
  
  与Windows下的Apache HTTP服务器集成:mod_jk_2.0.46.dll
  
  与Linux(RedHet)下的Apache HTTP服务器集成:mod_jk.so-ap2.0.46-rh72..46-rh72
  
  与IIS服务器集成:isapi_redirect.dll
  
  22.1.2 AJP协议
  
  AJP是为Tomcat与HTTP服务器之间通信而定制的协议,能提供较高的通信速度和效率。在配置Tomcat与HTTP服务器集成中,读者可以不必关心AJP协议的细节。关于AJP的知识也可以参考网址:
  
  http://jakarta.apache.org/builds/jakarta-tomcat-connectors/jk2/doc/common/AJPv13.html
  
  22.2 在Windows下Tomcat与Apache服务器集成
  
   Apache HTTP服务器是Apache软件组织提供的开放源代码软件,它是一个非常优秀的专业的Web服务器,为网络管理员提供了丰富多彩的Web管理功能,包括 目录索引、目录别名、内容协商、可配置的HTTP错误报告、CGI程序的SetUID执行、子进程资源管理、服务器端图像映射、重写URL、URL拼写检 查以及联机手册等。
  
  Apache HTTP服务器本身没有提供Servlet/JSP容器。因此,在实际应用中,把Tomcat与Apache集成,可以建立具有实用价值的商业化的Web 平台。在Windows NT/2000下Tomcat与Apache服务器集成需要准备的软件参见表22-1。
  
  表22-1 在Windows NT/2000下Tomcat与Apache服务器集成需要准备的软件
   Tomcat开发技术之与HTTP服务器的集成(图二) 
  1、安装Apache HTTP服务器
  
  运行apache_2.0.47-win32-x86-no_ssl.msi,就启动了Apache HTTP服务器的安装程序,只要按默认设置进行安装即可。如果安装成功,会自动在Windows中加入Apache HTTP服务,如图22-2所示。
   Tomcat开发技术之与HTTP服务器的集成(图三)
  图22-2 加入到Windows服务中的Apache服务
  
  假定Apache的根目录为,在其conf子目录下有一个配置文件httpd.conf。如果Apache安装在本机,并且采用默认的80端口作为HTTP端口,在httpd.conf文件中会看到如下属性:
  
  Listen 80
  ServerName localhost:80
  
  在操作系统的【开始】→【程序】→【Apache HTTP Server 2.0.47】→【Control Apache Server】菜单中,提供了重启(Restart)、启动(Start)和关闭(Stop)Apache服务器的子菜单。
  
  应该确保80端口没有被占用,否则Apache服务器无法启动。Apache服务器启动后,就可以通过访问Apache的测试页来确定是否安装成功。访问http://localhost,如果出现如图22-3所示的网页,就说明Apache已经安装成功了。
   Tomcat开发技术之与HTTP服务器的集成(图四)
  图22-3 Apache服务器的测试网页
  
  2、在Apache中加入JK插件
  
  在Apache中加入JK插件,只要把mod_jk_2.0.46.dll拷贝到/modules目录下即可。
  
  3、创建workers.properties文件
  
   workers.properties文件用于配置Tomcat的信息,它的存放位置为 /conf/workers.properties。在本书配套光盘的sourcecode/chapter22/windows_apache目录下提 供了workers.properties文件,它的内容如下("#"后面为注释信息):
  
  workers.tomcat_home=C:\jakarta-tomcat
  #让mod_jk模块知道Tomcat
  workers.java_home=C:\j2sdk1.4.2
  #让mod_jk模块知道j2sdk
  ps=#指定文件路径分割符
  worker.list=worker1
  worker.worker1.port=8009
  #工作端口,若没占用则不用修改
  worker.worker1.host=localhost
  #Tomcat服务器的地址
  worker.worker1.type=ajp13
  #类型
  worker.worker1.lbfactor=1
  #负载平衡因数
  
  以上文件中的属性描述参见表22-2。
  
  表22-2 workers.properties文件的属性
   Tomcat开发技术之与HTTP服务器的集成(图五) 
  4、修改Apache的配置文件httpd.conf
  
  打开/conf/httpd.conf文件,在其末尾加入以下内容:
  
  # Using mod_jk2.dll to
  redirect dynamic calls to Tomcat
  LoadModule jk_module
  modules\mod_jk_2.0.46.dll
  JkWorkersFile
  "conf\workers.properties"
  JkLogFile "logs\mod_jk2.log"
  JkLogLevel debug
  JkMount /*.jsp worker1
  JkMount /helloapp/* worker1
  
  在本书配套光盘的sourcecode/chapter22/windows_apache/httpd_modify.conf文件中提供了以上内容,它指示Apache服务器加载JK插件,并且为JK插件设置相关属性,这些属性的描述参见表22-3。
  
  表22-3 JK插件的相关属性
  Tomcat开发技术之与HTTP服务器的集成(图六) 
   JkMount用来指定URL映射信息,"JkMount /*.jsp worker1"表示"/*.jsp"形式的URL都由worker1代表的Tomcat服务器来处理;"JkMount /helloapp/* worker1"表示访问helloapp应用的URL都由worker1来处理。
  
  5、测试配置
  
  重启 Tomcat服务器和Apache服务器,通过浏览器访问http://localhost/index.jsp,如果出现Tomcat的默认主页,说明 配置已经成功。此外,如果在Tomcat服务器上已经发布了helloapp应用,可以访问http://localhost/helloapp /index.htm,如果正常返回helloapp应用的index.htm网页,说明配置已经成功。
  
  如果配置有误,可以查看JK插件生成的日志信息,它有助于查找错误原因。在Apache的配置文件httpd.conf中设定该日志文件的存放位置为/logs/mod_jk2.log
  
  6、Apache与多个Tomcat服务器集成时的负载平衡
  
   在实际应用中,如果网站的访问量非常大,为了提高访问速度,可以将多个Tomcat服务器与Apache集成,让它们共同分担运行 Servlet/JSP组件的任务。 JK插件的loadbalancer(负载平衡器)负责根据在workers.properties文件中预先配置的lbfactor(负载平衡因数)为 这些Tomcat服务器分配工作负荷,实现负载平衡。
  
  假定Apache和两个Tomcat服务器集成,一个Tomcat服务器和Apache运行在同一台机器上,使用的JK端口为8

分享到:
评论

相关推荐

    Apache+Tomcat整合

    例如,`route` 属性应与 Apache 中的 `BalancerMember` 节点保持一致,`port` 和 `redirectPort` 属性也需要调整以避免端口冲突。 最后,记得在配置完成后测试 Apache 的配置文件是否正确,可以使用 Apache 提供的 ...

    Apache+Tomcat+JK 实现集群负载均衡文档

    - `worker.tomcat1.port=8009` - `worker.tomcat1.host=localhost` - `worker.tomcat1.type=ajp13` - `worker.tomcat1.lbfactor = 1` 4. **创建uriworkermap.properties**:定义哪些URL请求应发送到哪个Tomcat...

    apache+tomcat整合配置

    &lt;Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /&gt; ``` 5. **测试与优化** 保存并重启Apache和Tomcat后,访问你的域名,如果配置正确,你应该能看到Tomcat部署的应用。为了提高性能,你可以...

    Apache+tomcat+ssl配置+相关插件

    这里,`ajp://localhost:8009/` 是指Tomcat的AJP连接器,它监听8009端口,Apache会将请求转发到这个端口。 至于Tomcat,你可能需要在server.xml文件中配置AJP连接器,确保Tomcat可以接收来自Apache的请求: ```xml...

    Apache + Tomcat集群配置详解

    在Tomcat方面,需要配置每个Tomcat实例的server.xml文件,开启AJP连接器,以便Apache可以通过AJP协议与Tomcat通信。在`server.xml`的`Connector`标签中添加如下配置: ```xml &lt;Connector port="8009" protocol="AJP/...

    linux下apache+tomcat实现集群

    Apache通过模块如mod_proxy或mod_proxy_ajp与Tomcat进行通信。 1. **Apache配置**: - 安装Apache:在Red Hat 5上,使用`yum install httpd`命令安装Apache。 - 配置mod_proxy:启用mod_proxy模块,编辑`/etc/...

    apache+tomcat集群配置

    这通常涉及到添加`&lt;Connector&gt;`元素,并设置相关的属性,如`protocol="AJP/1.3"`、`port="8009"`等。 **测试JK连接:** 完成配置后,可以通过重启Apache和Tomcat,然后发送HTTP请求来测试JK连接是否正常。可以使用...

    apache+tomcat 实现负载均衡

    AJP是Apache提供的完成与其它服务器通讯的一种协议。在Apache中通过mod_proxy_ajp模块发送AJP数据,另外一端的服务器需要实现AJP协议,能够接受mod_proxy_ajp模块发送的AJP协议数据,在接受到AJP协议数据后做适当...

    apache+tomcat+memcache

    Apache配置的重点在于启用适当的模块以支持负载均衡和AJP协议。在`httpd.conf`文件中添加以下模块: 1. **LoadModule**:开启`mod_proxy`、`mod_proxy_ajp`、`mod_proxy_balancer`等模块。这些模块使得Apache能够...

    apache+Tomcat负载平衡设置详解

    - `ajp12` 类型:使用 AJP/1.2 协议,通过 TCP/IP 连接与 Tomcat 通信,如 `worker.local.type=ajp12`。 - `ajp13` 类型:使用 AJP/1.3 协议,功能类似但更优化,如 `worker.remote.type=ajp13`。 - `jni` 类型:...

    Apache+Tomcat的 整合

    5. 配置Tomcat:修改Tomcat的server.xml文件,开启AJP连接器,让Tomcat监听8009端口接收来自Apache的请求。 ```xml &lt;Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /&gt; ``` 6. 重启服务:最后...

    apache2.2 + tomcat6 配置方式

    - 防火墙设置:确保服务器上的80端口(Apache)和8009端口(Tomcat的AJP连接器)对必要的IP开放。 - 错误日志:监控Apache和Tomcat的日志文件,以解决配置过程中可能出现的问题。 - 安全性:使用SSL加密连接,以...

    linux_apache+tomcat负载均衡安装和调试.pdf

    《Linux Apache + Tomcat 负载均衡安装与调试详解》 在当今互联网环境中,高可用性和可扩展性是服务器架构的重要考量因素。Linux、Apache 和 Tomcat 的组合是搭建高性能 Web 应用服务器的常见选择,而通过负载均衡...

    Windows平台上的Apache+Tomcat配置指南[归纳].pdf

    Windows平台上的Apache+Tomcat配置...worker.ojava.type=ajp13 worker.ojava.host=localhost worker.ojava.lbfac, 通过以上步骤,我们已经成功地配置了Apache和Tomcat的整合环境,可以为Java平台的Web应用提供服务。

    tomcat集群-Apache2.2.4+And+mod_jk.so+tomcat配置文件

    【描述】中的"apache的安装包和链接tomcat的插件,以及tomcat和apache的配置文件"表明,你需要配置Apache服务器(版本2.2.4)和mod_jk模块来与多个Tomcat实例(如tomcat3、tomcat2、tomcat1)进行通信。此外,还需要...

    Apache2.2.3+Tomcat6.X整合

    worker.ajp13.port=8009 worker.ajp13.lbfactor=1 ``` 接着,将`mod_jk.so`模块添加到Apache的`modules`目录下。这个模块是Apache与Tomcat通信的关键,负责负载均衡和请求转发。 修改Apache的配置文件`httpd.conf`...

    Apache2.2.11 + Tomcat 6.0.20 集群配置详解

    Apache2.2.11与Tomcat 6.0.20集群配置是一项重要的技术实践,旨在提高Web服务的可用性和性能。集群能够实现负载均衡,即将请求分发到多个服务器,避免单点故障,同时通过session共享确保用户在集群中的无缝切换。...

    Apache2+Tomcat7负载均衡配置(超详细整合文档)

    在这个配置中,`worker.list`定义了所有worker的列表,每个worker的`type`指定了连接协议(这里是ajp13),`host`和`port`分别表示Tomcat服务器的IP和AJP端口,`lbfactor`用于设置权重,数值越大,负载越高。...

    APACHE 2.2.9+TOMCAT6.0.18配置负载均衡

    这里是apache和tomcat链接的关键,前台apache就是通过AJP协议与tomcat进行通信的,以完成负载均衡的作用。也可以用HTTP协议。大家注意它们是如何连接通信的,上面的红色部分(port="8009")就是连接的接口了。 把四...

Global site tag (gtag.js) - Google Analytics