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所示。
   
  图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服务器集成需要预备的软件
   
  1、安装Apache HTTP服务器
  
  运行apache_2.0.47-win32-x86-no_ssl.msi,就启动了Apache HTTP服务器的安装程序,只要按默认设置进行安装即可。假如安装成功,会自动在Windows中加入Apache HTTP服务,如图22-2所示。
   
  图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已经安装成功了。
   
  图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文件的属性
   
  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插件的相关属性
  
 
 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

摘自http://www.studyems.com/network/85500f121604b5b9.html

时间: 2024-08-28 00:33:27

Tomcat开发技术之与HTTP服务器的集成的相关文章

《Tomcat与Java Web开发技术详解》思维导图

越想构建上层建筑,就越觉得底层基础很重要.补课系列. 书是良心书,就是太基础了,正适合补课. [纯文字版] Tomcat与Java Web开发技术详解 Servlet Servlet的生命周期 初始化 1Servlet容器加载Servlet类 2Servlet容器创建ServletConfig,初始化配置信息 3Servlet容器创建Servlet对象 4Servlet容器调用Servlet对象的init(ServletConfig) 时机:首次被请求或配置了<load-on-startup>

手游服务器开发技术详解

从事游戏服务器开发差不多两年时间,两年间参与了不少项目,学到了很多游戏服务器开发技术,参与过几个不同架构的服务器开发,就随便聊聊游戏服务器开发需要的技术.(以下所指游戏服务器更偏向于手游,因为我对端游和页游开发接触并不多) 一.聊聊服务器开发有哪些东西要考虑. 1.开发语言的选择: 工欲善其事,必先利其器,选择一门适合的开发语法对后期开发有着事半功倍的作用. 业界主要的是c/c++ + Python/lua模式做游戏服务器.c/c++做网络通讯数据传输,python/lua做业务逻辑.这样既保持

web开发的背景及常用服务器

一.web开发的相关知识 WEB,英语中web即表示网页的意思,它用于表示Internet主机上外界访问的资源. Internet上供外界访问的web资源分为: 静态web资源(如HTML页面):指web页面中供人们浏览的数据始终是不变的. 动态web资源:指web页面供人们浏览器的数据是由程序产生的,不同时间点访问web页面看到的内容各不相同. 静态web资源开发技术:HTML.css.JavaScript. 动态web资源开发技术: jsp/servlet.ASP.PHP.Python等.

微信公众号开发技术基础(二):外网映射工具ngrok的简介和使用

本文结构:(一)用法(二)示例(三)qydev ngrok的下载链接及相关网站 微信公众号开发的时候,微信服务器是需要访问我们的一个公网服务器地址的,但我们又是在本地调试自己的程序的,那怎样让微信服务器能访问到我们本地的服务器呢?那就需要用外网映射工具,将本地IP映射成公网IP,这样就能在公网上访问本地服务了,这里使用ngrok.ngrok原版程序的服务器是在国外的,访问速度极慢或者干脆访问不了,所以这里提供一个服务器搭建在国内的基于ngrok的一个软件:qydev,百度网盘下载链接见文章结尾.

Android开发技术周报

Android开发技术周报 原文  http://androidweekly.cn/android-dev-weekly-issue48/ 教程 深入理解Android之Gradle Gradle是当前非常“劲爆”得构建工具.本篇文章就是专为讲解Gradle而来.介绍Gradle之前,先说点题外话.说实话,我在大法工作的 时候,就见过Gradle.但是当时我一直不知道这是什么东西.而且大法工具组的工程师还将其和Android Studio大法版一起推送,偶一看就更没兴趣了.为什么那个时候如此不待

第一章 Java Web应用开发技术

1.Java Web应用开发技术 Java Web应用开发是基于JavaEE(JavaEnterprise Edition)框架的,而JavaEE是建立在Java平台上的企业级应用解决方案.JavaEES框架提供的Web开发技术主要支持两类软件的开发和应用,一类是做高级信息系统框架的Web应用服务器(Web Application Server),另一类是在Web服务器上运行的Web应用(Web Application).我们以后所说的Java Web应用开发就是这里的第二类.即在Web服务器上

如何配置Java EE Eclipse+Tomcat 开发环境

如何配置Java EE Eclipse+Tomcat开发环境 本文来源于鸡啄米 http://www.jizhuomi.com/ , 原文地址:http://www.jizhuomi.com/software/357.html 以下将详细介绍在Eclipse下搭建Java EE开发环境的每一步, 环境:Win 7 + JDK 1.7 + Eclipse IDE for Java EE Developers 3.7 +Tomcat 6.0 首先准备好一下软件: JDK:jdk-7u3-window

XACS系统开发技术介绍

XACS系统基于Java语言,采用主流的开源技术框架,在模块设计上遵循低藕合,高内聚的原则,达到普通应用下开发简单快速,易上手:复杂环境大规模应用情况下易整合,易部署:良好的模块化设计可以满足方便的和其它业务系统或工单管系统集成,拓展北向接口功能. XACS采用的技术及框架有: 1. 数据库MySQL 在XACS中集成了MySQL数据库,可以控制MySQL数据随系统的启停而启动停止,不需要另外安装MySQL数据库系统. 在实际应用中,也可以根据需要选用其它数据库系统如PostgreSQL, Or

嵌入式开发技术三级

1.酒店客房的门锁系统是由总台服务器和若干客房指纹锁组成,其基本功能具体描述如下: a.客房的指纹锁与总台服务器之间通过通信网络连接. b.旅客在总台登记住宿时,录入其指纹信息,并提取其特征值存储在总台服务器中.同时录入一个密码(若干位数字组成),以备指纹无法开锁时,用密码开锁. c.旅客在开客房指纹锁时,把相应手指放在门锁的指纹采集部件上,采集相应的指纹图像信息,并传输给总台服务器. d.总台服务器接收到某个客房指纹锁传输来的指纹图像信息后,进行特征值求取并进行匹配,若匹配正确,则回送开锁指令