服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

tomcat开发技术之与http服务器的集成


  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所示。
   tomcat开发技术之与http服务器的集成(图一)
  图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

扫描关注微信公众号