历时4个多小时,终于把tomcat与apache整合起来了。

中间出了各种各样的问题,现记录一下,也希望能对后来者有点帮助。

背景

apache与tomcat的区别联系大家都知道:

tomcat能处理jsp页面,也能处理html页面

apache只能处理静态资源,如html页面,图片,js等等,而且apache处理html页面比tomcat处理html的速度快。





那为了提升整个系统的访问速度。

我们就把apache与tomcat整合到一起,我们发的所有请求都是先给apache,如果具体的请求是html(还包括.jpg,.js等静态资源)就直接让apache处理,如果是jsp或servlet等动态信息,就交给tomcat处理。

下载与安装

jdk 1.7

tomcat 6  (tomcat7在整合中似乎有些问题,大家就用tomcat6吧)

apache 2.2.4

mod_jk 这就是把apache无法处理的动态请求发送给tomcat的东西。 这里要注意,mod_jk的版本一定要与apache的版本匹配

我建议大家就直接在百度上搜 "mod_jk-1.2.26-httpd-2.2.4" 或者去http://download.csdn.net/download/wng1978/6708623 这里直接下载

我一直强调版本问题,就是因为我自己下载的各种组件的版本不匹配,中间浪费了很多时间。

因此,我再说句题外话

大家在新接触一个东西时,特别是还处在搭环境的阶段的时候,下载的各个组件最好就按照你所阅读的那个文章所说的版本,这样至少不会出现版本冲突的问题。

初学者,一旦碰到这种版本问题,是很打击积极性的。

整合

mod_jk

解压缩mod_jk-1.2.26-httpd-2.2.4.rar,得到mod_jk-1.2.26-httpd-2.2.4.so,将它改名为mod_jk.so后放到apache的安装目录下的modules中。

编辑apache/conf/httpd.conf文件

找到Listen 80这一行( ctrl+f )修改为 Listen 81

在httpd.conf的最后加上

 # 设置虚拟主机,定义端口为81
 <VirtualHost 127.0.0.1:81>
     ServerName 127.0.0.1
     #定义服务名称 E:/apache-tomcat-6.0.44-8500/webapps 是我的tomcat的位置
     DocumentRoot "E:/apache-tomcat-6.0.44-8500/webapps"
     #定义站点项目所在路径,把路径指向 tomcat 中的默认网站目录
     DirectoryIndex index.html index.htm index.jsp
     ErrorLog logs/shsc-error_log.txt

     ##下面例子中的ajp13,请大家记住,后面咱们还要用
     CustomLog logs/shsc-access_log.txt common
     #例子1,让 Apache 支持对webapps/sun.shop/blog 中页面传送
     JkMount /sun.shop/blog/* ajp13
     #例子2,向Apache请求此文件夹内页面时,系统将转向用Tomcat解析
     JkMount /*.jsp ajp13

     #例子4,向 Apache 请求jsp页面时,用 Tomcat 进行解析
     JkMount /*.do ajp13
     #例子5,向 Apache 请求.do 动作时, 用 Tomcat 进行解析
     JkMount /*.action ajp13
     #例子6,向 Apache 请求 .action 动作时, 用 Tomcat 进行解析

 </VirtualHost>

 # 允许客户端访问此路径
 <Directory "E:/apache-tomcat-6.0.44-8500/webapps">
     Options Indexes FollowSymLinks
     AllowOverride None
     Order allow,deny
     Allow from all
 </Directory>  

说实话,我不知道Directory后面那个目录与virtualhost里面那个documentroot中的目录有什么区别联系

目前,我设置这个两个路径一直,都是tomcat下的webapps

到这一步后,我们先检查一下,apache是否已经安装好了。

检查

我已经在E:/apache-tomcat-6.0.44-8500/webapps 下部署了一个叫PathTest的项目,根目录下有个index.html文件。

http://localhost:81/PathTest/

在浏览器中输入上面的地址。



换一个地址

如果你的浏览器也能出现类似上面的效果,说明apache本身已经安装好了。

连接tomcat

将apache连接到tomcat上

再给httpd.conf后面加上以下内容

 LoadModule jk_module modules/mod_jk.so
 # 此处 mod_jk.so 文件为你下载的文件
 JkWorkersFile "E:/apache-tomcat-6.0.44-8500/conf/workers.properties"
 # 指定tomcat监听配置文件地址
 JkLogFile "E:/apache-tomcat-6.0.44-8500/logs/mod_jk2.log"
 # 指定日志存放位置
 JkLogLevel info

上面tomcat的地址大家根据自己的改动一下即可。

设定tomcat

设定tomcat那边如何接受apache的请求。

在上一步里我们有这样的配置

     JkWorkersFile "E:/apache-tomcat-6.0.44-8500/conf/workers.properties"

     在那么去tomcat的conf目录下看看,并没有workers这个文件,怎么办?新建一个就可以了嘛。并写入如下内容:

workers.tomcat_home=E:\apache-tomcat-6.0.44-8500 #让mod_jk模块知道Tomcat的位置
workers.java_home=C:\Program Files\Java\jre7 #让mod_jk模块知道jre的位置
ps=\
worker.list=ajp13 #模块版本
worker.ajp13.port=8009 #工作端口,若没占用则不用修改
worker.ajp13.host=localhost #本机,若上面的Apache主机不为localhost,作相应修改
worker.ajp13.type=ajp13 #类型
worker.ajp13.lbfactor=1 #代理数,不用修改

大家看这一行

worker.list=ajp13 #模块版本

这个ajp13和httpd.conf中的 JkMount /sun.shop/blog/* ajp13 的ajp13 是对应的

你把两处的ajp13改成"mytomcat"也是可以的。

还有 worker.ajp13.port=8009 这个端口指的是tomcat中ajp协议的端口,不是我们经常用的那个支持http的8080。

换句话说这个8009,最好就不要改。

另外,我的tomcat的端口号改成了8500。

在什么地方改?





在tomcat/conf/server.xml下

    <Connector port="8500" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

8500与8009分别支持两种协议。





OK,现在我们试一试。

开启tomcat,访问 http://localhost:8500/PathTest/jsp/a.jsp

是一个很简单的jsp

开启apache,

对了还没有说怎么开启apache服务呢。

在apache/bin下有个ApacheMonitor。双击







选定服务后,start即可。

然后访问  http://localhost:81/PathTest/jsp/a.jsp

注意,我们的端口号是81,是访问apache的。

apache看到请求的地址是jsp,就通过JkWorkersFile找到apache后面的tomcat,tomcat处理后,再把结果给apache,然后apache再给浏览器。

如果http://localhost:81/PathTest/jsp/a.jsp 和 http://localhost:8500/PathTest/jsp/a.jsp 的返回结果一样。

就说明apache与tomcat整合完毕。

可能出现的问题

1 启动apache的时候 弹出这个错误 the requested operation has failed

  如果不是端口问题的话,那么就是httpd.conf被我们修改错了。

  怎么办

命令行内进入安装目录apache\bin,使用命令httpd -t,然后出现“Syntax error on line 133 of E:/apache\conf/httpd.conf :ServerAdmin takes one argument, the email address of the server administrator”,看它提示信息,说明,在这个配置文件里面的133行,出现了问题

上面的133行错误是什么意思呢?

给后面加上一个地址就OK

2 上面的配置中,我们在81端口,访问html,jsp,js,jpg都是没有问题的,深入甚至加入mvc框架后的.do,.action都可以正常处理。

  可是我们如果访问的是servlet呢?

  目前没有特别好的方法。

  给httpd.conf下的VirtualHost里面加上这个

  JkMount /*/servlet/* ajp13 

  这是什么意思?

如果请求的url中间包含"servlet"这个字符,apache就把它发给tomcat。

这篇文章参考了很多博客,具体参考信息就不一一列出了

tomcat整合apache的更多相关文章

  1. Geronimo tomcat: 在 Apache Geronimo 插件体系中将 Apache Tomcat 这个优秀的 Web 容器整合至其中

    Apache Geronimo 灵活的插件体系将 Tomcat, OpenJPA, OpenEJB, ActiveMQ 等第三方组件集成至其中.本文从多角度介绍了在 Apache Geronimo 中 ...

  2. apache和tomcat有什么不同,为什么要整合apache 和tomcat

    1. Apache是web服务器,Tomcat是应用(java)服务器,它只是一个servlet容器,是Apache的扩展.2. Apache和Tomcat都可以做为独立的web服务器来运行,但是Ap ...

  3. debian下Apache和tomcat整合(使用apt工具)

    最近部署web系统,需要使用tomcat处理和Apache整合使用,tomcat处理JSP,Apache处理静态资源.开始不知道怎么操作,在网上查阅资料走了很多弯路.完成时候,发现其实很简单,现将配置 ...

  4. windows平台整合Apache与tomcat

    Apache与Tomcat整合的好处 Apache主要用来解析静态文本,如html.Tomcat虽然也有此功能,但Apache效率大大高于Tomcat,尤其是对于并发数较大的企业级应用,能更好的显示A ...

  5. apache和tomcat有什么不同,为什么要整合apache 和tomcat?

    1. Apache是web服务器,Tomcat是应用(java)服务器,它只是一个servlet容器,是Apache的扩展.2. Apache和Tomcat都可以做为独立的web服务器来运行,但是Ap ...

  6. apache+tomcat整合后的编码问题

    apache+tomcat整合提供webserver服务的方式是为了实现两个目的:一是方便利用apache http server将客户请求均衡的分给tomcat1,tomcat2....去处理,即负 ...

  7. 在CentOS下企图整合Apache和Tomcat依然失败

    环境: 64位CentOS  Linux version 2.6.32-431.el6.x86_64 CentOS release 6.5 (Final) Apache/2.2.15,mod_jk/1 ...

  8. apache+tomcat整合

    一 .Apache与Tomcat的比较 apache支持静态页面,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是 ...

  9. Apache与Tomcat整合

    Apache与Tomcat整合   一 Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache ...

随机推荐

  1. Dynamics CRM2016 Web Api之分页查询

    在dynamics crm web api还没出现前,我们是通过fetchxml来实现的,当然这种方式依旧可行,那既然web api来了我们就拥抱新的方式. web api中我们通过指定查询的条数来实 ...

  2. Github Atom开源文本代码编辑器- 由 Github 打造的下一代编程开发利器

    个人理解:Github 热度超凡的一个项目Atom,electron是整个atom的核心,对于electron可以理解成 electron =io.js + Chromium    通过 Electr ...

  3. hadoop入门级总结三:hive

    认识hive  Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供完整的SQL查询功能,可以将SQL语句转换为MapReduce任务运行  Hive是建立在 ...

  4. jdbc批量插入

    分享牛,分享牛原创.有这样一个需求,文本文件中的数据批量的插入mysql,怎么用jdbc方式批量插入呢? jdbc默认提供了批量插入的方法,可能用一次就忘记了,这里做笔记记录一下jdbc批量插入吧. ...

  5. Apache shiro集群实现 (七)分布式集群系统下---cache共享

    Apache shiro集群实现 (一) shiro入门介绍 Apache shiro集群实现 (二) shiro 的INI配置 Apache shiro集群实现 (三)shiro身份认证(Shiro ...

  6. XMPP(二)-基于asmack+openfire的安卓客户端(仿QQ)的介绍以及个人心得

    关于XMPP第一篇-openfire的搭建写完后,就一直在赶本篇所要介绍的这个基于asmack+openfire的安卓客户端,费了不少精力,因为有不少同学在还在焦急的等待着(自恋了呵呵),所以紧赶慢赶 ...

  7. 移动开发测试工具——Bugtags的集成

    移动开发测试工具--Bugtags 官网:https://bugtags.com/ 注册开发者账号 注册账号并激活邮箱,都会就不多做介绍了. 创建应用 创建完账号以后会提示添加应用,点击添加 添加应用 ...

  8. 剑指Offer——丑数

    剑指Offer--丑数 前言     参照<剑指Offer>,通过洞悉其思想并消化吸收,改为java实现,供自己以后巩固. package cn.edu.ujn.offersword; i ...

  9. UE4成批处理透明材质

    项目中需要控制成批的物体的透明度,但是默认的时候他又不能是透明的,对,项目的要求就这么诡异. 然而却没有找到设置材质的BlendMode的功能,于是只有换了一种办法,物体需要透明时更换为透明材质,默认 ...

  10. 18 UI美化自定义主题样式代码

    自定义主题 假设我们我们对现有的样式不大满意 那么可在工程目录res/values下的styles.xml自定义 方法: 1. res/values下的styles.xml文件中自定义一个标签 < ...