- 论坛徽章:
- 0
|
关于整合的文章特别是精华基本都看了,但是对于一个菜鸟来说,真的有好多地方看不懂,不仅这些整合的文章,其实对于好多帖子也有这个感觉,所以很希望这些高手能够多做一些解释和说明,以解我们心中之惑。
下面谈谈我对整合理解与疑惑,有太多的不明白,所有其中有很多的臆想成份,请高手指正与解惑。
整合的目的
------------------------------------------------------------------------------
Tomcat是Sun和Apache合作, 做出来的JSP Server, 支持Servlet 和JSP。Tomcat本身可以做为Web Server, 当处理静态页面时,Tomcat不如Apache迅速,不象Apache一样可配置,强壮。 Apache做为最流行的Web服务器功能强大,高效,但并不支持JSP及servlet,所以通常的做法是把它们整合起来,让Apache处理静态页面,而把动态页面的请求交给Tomcat处理,发挥各自的优势。通过在Apache中加载整合模块和进行设置,Apache就能够根据URL,把不属于自己的请求转给Tomcat。
要让Apache和Tomcat联合工作,还必需有一个连接器把它们联系起来。Connector对于性能、配置的方便性有很重要的影响,目前大致上有JK1.x、JK2、mod_webapp三种connector可以使用。JK使用比较广泛,JK2是JK1.x的改进,比较新。这三种Connector的配置方法大相径庭。本文只介绍我所用的JK2的整合方法。
版本的选择的相关性:
------------------------------------------------------------------------------
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中起作用的可能就是在第一个后面紧挨着的对于整合在起作用吧,没有应该加上。
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的修改
在虚拟主机之前加入
Order allow,deny
Deny from all
#因为apache与tomcat指向相同的目录,所在要禁止对WEB-INF的访问。
在虚拟主机的配置中
JkUriSet worker ajp13:localhost:8009
#这可能是做映射,将目录中的jsp和servlet由tomcat解析。
server.xml的修改
在虚拟主机的host中加入
(这个tomcat很奇怪,不像apache只要指定DocumentRoot,那么网站的逻辑根目录就是DocumentRoot指定的了,而tomcat用appBase指定的应该叫什么呢?要用上面的一句将appBase指定的目录声明为根目录,appBase下其它目录默认情况下就是网站逻辑子目录)
关于虚拟主机整合的配置,JK文档的例子说得很清楚,或看本版的一篇精华。
------------------------
我就理解这么多,对于jk2.properties,workers2.properties,tomcat,apache里的配置参数根本很少了解,我想把它们理解了也许就明白了。。。。。。
诚惶诚恐,请大侠指正,以免害人
本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/6563/showart_25594.html |
|