整合tomcat和apache

来源:互联网 发布:react 整合 java 编辑:程序博客网 时间:2024/05/02 17:42

整合的目的(完全臆想)
------------------------------------------------------------------------------
apache 和 tomcat都可以做为独立的WEB服务器来用,apache功能强大、高效,但并不能支持JSP及serlet,而tomcat正相反,所以要把它们结合起来。
通过在apache中加载整合模块和进行设置,apache就能够根据url,把不属于自己的请求转给tomcat.

版本的选择的相关性:
------------------------------------------------------------------------------
1.Apache
httpd2.0.x,对于与apache1.3.x等版本有什么区别不知道,应该有个飞跃吧,连名字都改成httpd了。而我们选择了用JK2整合,JK2是针对apache2.0的思想开发的(英语太差,见原文:JK2 has been developed with Apache 2.0 in mind),所以选择用httpd2.0.x。

2.整合方式-JK2
为什么选择JK2呢?(JK is a replacement to the elderly mod_jserv. It was a completely new Tomcat-Apache plug-in that handles the communication between Tomcat and Apache.The newest JK2 is a refactoring of JK . The native part has been completly restructured and the configuration has been simplified a lot.)我只看重了最后一句话,呵呵。在JK的文档中有关于以前的整合模块及JK、JK2功能的详细描述。

3.Tomcat5.0、J2SDK1.4.x
能够支持JAVA,JSP,及Servlet的较新标准吧?它们之间应该有一定的关联,据说tomcat5及JDK1.4对中文的支持方式改变了不少,现在不用进行复杂的设置了就可以很好的使用中文,但对于针对以前JSP标准开发的页子的中文兼容性不太好。

编译安装过程中的注意事项:
-------------------------------------------------------------------------------
1.Apache
必须编译成允许动态加载模块的方式,即在configure时要加 --enable-so选项,因为将来要加载mod_jk2这个整合模块。
假设apache的安装目录为PathofApache,则编译的模块在PathofApache/modules下,配置文件在PathofApache/conf下。

2.tomcat
只会用编译好的版本。解压、释放包就行了。(听说tomcat是JAVA写的,不知道用那个ANT编译有什么优势也没试成功过),假设tomcat安装目录为PathOfTomcat。

3.JDK
我用的是二进制版本,直接运行,自己解压释放包。(如果用那个RPM包我不知道JAVA_HOME怎么设,呵呵)设置JAVA_HOME和CLASSPATH环境变量。JAVA_HOME也可以不设置而在PathOfTomcat/bin/catalina.sh中赋值,CLASSPATH目前我还没设置,也许在JSP中要用到JAVA标准类的时候要用到。

4。JK2模块编译
假设JK2包释放后目录改名为PathOfJK2,且当前目录为PathOfJK2(
参考JK文档,注意关于编译的部分在JK部分有说明,而默置要看JK2部分,因为不同的整合方式有很大的不同。http://jakarta.apache.org/tomcat/tomcat-4.1-doc/jk2/


cd jk/native2

chmod +755 buildconf.sh
./buildconf.sh (因为buildconf.sh没有执行权,所以要改,但“零二年的夏天”告诉我只要 sh buildconf.sh就可以执行了)

./configure --with-apxs2=PathOfApache/bin/apxs
这个apxs在apache的安装目录的bin下,所以要先装apache。据说只有编译安装的apache才有这个文件,rpm包安装的没有这个文件,如果要给rpm包安装的apache编译整合模块,要找一个相同版本的编译一下用然后再删掉,版本号要完全相同,否则编译出来的模块不能用。
还有两个参数我没有,英文的说明也没看太懂,就在JK的文档中有说明:
--with-apache=DIR,DIR is the path where apache sources are located. The apache sources should have been configured before configuring mod_jk. DIR is something like: /home/apache/apache_1.3.19 It builds a static Apache module.
--enable-EAPI,This parameter is needed when using Apache-1.3 and mod_ssl, otherwise you will get the error message: "this module might crash under EAPI!" when loading mod_jk.so in httpd. Not needed when --with-apxs has been used

另外,我在执行configure的时候提示有错误,好像是关于路径的,我就先启动了tomcat,执行通过。(也许是我没有设置关于tomcat目录的环境变量的原因)
make
make install

所有的文档都说如果发布不成功,那么要手工发布,我也是手工发布的:
cp PathOfJK2/build/jk2/apache2/mod_jk2.so PathOfApache/modules/

配置文件的修改
-------------------------------------------------------------------------------
JK2所用的配置文件有2个:
jk2.properties,默认要放在PathOfTomcat/conf中
workers2.properties默认要放在PathOfApache/conf中

这两个文件的作用真的不明白,jk2.properties可能是定义tomcat与apache的通讯端口等,workers2.properties可能是告诉apache有哪些目录是tomcat支持的。

1.在PathOfTomcat/conf中有tomcat的主配置文件server.xml和JK2的配置文件jk2.properties。
    实际上我对这两个文件没有做任何修改,而jk2.properties缺省就是空的。看了看在server.xml中起作用的可能就是在第一个后面紧挨着的对于整合在起作用吧,没有应该加上。
<!-- Define a Coyote/JK2 AJP 1.3 Connector on port 8009 -->
<Connector port="8009" enableLookups="false"  redirectPort="8443" debug="0"
protocol="AJP/1.3" />

2.在PathOfApache/conf中有apache的配置文件httpd.conf,及JK2配置文件workers2.properties
修改httpd.conf,只加入:LoadModule jk2_module modules/mod_jk2.so
关于workers2.properties,引用JK文档例子中最小配置如下:
# Define the communication channel
[channel.socket:localhost:8009]
info=Ajp13 forwarding over socket
tomcatId=localhost:8009

# Map the Tomcat examples webapp to the Web server uri space
[uri:/examples/*]
info=Map the whole webapp

这个/examples应该是tomcat下的路径而不是apache的,但在这里做了映射,这个URL就能被apache接受并转给tomcat,而不用加tomcat的端口号了。
这样就完成了一种整合方式,这可能是最简单但很少用的配置方法吧
——————————————————————————

还有一种配置的方法很实用,但有一点地方不明白,适合做虚拟主机。

1.把apache与tomcat都做虚拟主机,并且相同的主机指向相同的根目录
2,默认情况下:jk2.properties可为空,workers2.properties不用做地址映射(?)
3.除了做虚拟主机,还要做如下修改
http.conf的修改
在虚拟主机之前加入
<Directory ~ "/WEB-INF/">
Order allow,deny
Deny from all
</Directory>
#因为apache与tomcat指向相同的目录,所在要禁止对WEB-INF的访问。

在虚拟主机的配置中
<Location ~ "/*.jsp|/*/servlet/*">
JkUriSet worker ajp13:localhost:8009
</Location>
#这可能是做映射,将目录中的jsp和servlet由tomcat解析。

server.xml的修改

在虚拟主机的host中加入
<Context path="" docBase="" debug="1"/>
(这个tomcat很奇怪,不像apache只要指定DocumentRoot,那么网站的逻辑根目录就是DocumentRoot指定的了,而tomcat用appBase指定的应该叫什么呢?要用上面的一句将appBase指定的目录声明为根目录,appBase下其它目录默认情况下就是网站逻辑子目录)

关于虚拟主机整合的配置,JK文档的例子说得很清楚,或看本版的一篇精华。
------------------------

我就理解这么多,对于jk2.properties,workers2.properties,tomcat,apache里的配置参数根本很少了解,我想把它们理解了也许就明白了。。。。。。
 

 

  1.下载jk2,此插件用于整合apache和其它服务器(IIS、Tomcat均在此列),没有它我们就什么也玩不转了。下载地址:http://archive.apache.org/dist/jakarta/tomcat-connectors/jk2/binaries/win32/jakarta-tomcat-connectors-jk2.0.4-win32-apache2.0.49.zip,或者你可以到http://archive.apache.org/dist/jakarta/tomcat-connectors/jk2/这里去找合适的版本,以后肯定会有更新的版本,到时再直接给大家下载路径就无效了,呵呵。
  2.jk2是目前最新的版本,以前有jk,相比jk,jk2功能更加强大,如何强大?好像是支持jni之类的东西,我没有深研究,现在也用不上,反正你只要知道jk2好,强大即可。jk2支持所有版本的apache和所有版本的tomcat整合。
  3.在apache的conf下建立workers2.properties(必须用这个名字,否则即使在httpd.conf里JkSet config.file conf/workers.properties这样自定的名字也是不好用的,反之起了这个名字,这个指令也是多余的),它的作用是指定apache把什么路径的什么文件转发给tomcat运行等等信息,如:
[channel.socket:localhost:8009]
port=8009
host=127.0.0.1

[ajp13:localhost:8009]
channel=channel.socket:localhost:8009

[uri:/examples/*.jsp] #examples代表tomcat里的一个虚拟路径,可以写任意个虚拟路径,每个虚拟路径可以有任意个可转发给tomcat的扩展名的匹配
[uri:/task4/*.jsp]#另一个虚拟路径,指示apache,只把task4的工程的jsp文件转发给tomcat运行。
worker=ajp13:localhost:8009 #不知何用
4.在apache的conf/httpd.conf的末尾加上:
     LoadModule jk2_module "modules/mod_jk2.so",这里的路径分隔符用/和/都可以,没有影响。这句话的作用是加载jk2的模块文件。
5.把jk2的文件mod_jk2.so拷贝到apache的modules里

注:
1.tomcat默认用8009端口监听其它和它整合的服务器
2.启动tomcat和apache的顺序:先启动tomcat,等它启动完后,再启动apache,否则会报错:内部错误。
3.jk2比jk功能更强大。
4.如何证明整合成功?
 运动同一个页面,路径一个写端口(tomcat),一个不写端口(apache),都能正常运行,证明成功。 
5.apache的端口默认是80