一、 apache与tomcat整合的必要性
Apache是最流行的Web服务器,开放源代码,支持跨平台的应用(可以运行在几乎所有的Linux、Unix、Windows系统平台上),尤其对Linux的支持相当完美。
apache的优点有:
1、功能强大,apache自带了很多功能模块,可根据需求编译自己需要的模块。
2、配置简单,apache的配置文件非常简单,通过简单的配置可实现强大功能。
3、速度飞快,apache处理静态页面文件效率非常高,可以应对大并发和高负荷访问请求。
4、性能稳定,apache在高负荷请求下性能表现卓越,执行效率非常高。
但是apache也有自身的缺点:
1、只支持静态网页,对于jsp、php等动态网页不支持
2、Apache是以进程为基础的结构,进程要比线程消耗更多的系统开支,因此,不太适合于多处理器环境。
Tomcat是Sun和Apache合作做出来的JSPServer,有如下优点:
1、支持Servlet和JSP,可以很好的处理动态网页。
2、跨平台性好:Tomcat是Java程序,所以只要有JDK就可以使用,不需要考虑操作系统平台。
但是,tomcat也有自身缺点:
1、处理静态页面效率不高:Tomcat本身可以做为Web Server,但是tomcat在处理静态页面时没有Apache迅速。
2、可配置性不强:tomcat不像Apache一样配置简单,稳定、强壮。
综上所述,通过相互的整合刚好弥补了各自的缺点,通过整合可以实现:
1、客户端请求静态页面时,由Apache服务器响应请求。
2、客户端请求动态页面时,则是Tomcat服务器响应请求。
3、通过apache信息过滤,实现网站动、静页面分离,保证了应用的可扩展性和安全性。
既然要让Apache和Tomcat协调工作,就必需有一个连接器把它们联系起来,这就是下面要提到的Connector,下个小节具体讲述Connector的选择和使用。
二、 Apache和Tomcat连接器
Apache是模块化的web服务器,这意味着核心中只包含实现最基本功能的模块。扩展功能可以作为模块动态加载来实现。为了让apache和tomcat协调工作,开源爱好者们开发出了很多可以利用的模块,在Apache2.2版本之前,一般有两个模块可供选择:mod_jk2和mod_jk,mod_jk2模块是比较早的一种连接器,在动、静页面过滤上可以使用正则表达式,因此使用配置灵活,但是mod_jk2模块现在已经没有开发人员支持了,版本更新也就此停止。继承jk2模块的是mod_jk模块,mod_jk模块支持Apache 1.x和2.X系列版本,现在一般都使用mod_jk做Apache和Tomcat的连接器。
在Apache2.2版本以后,又出现了两种连接器可供选择,那就是http-proxy和proxy-ajp模块,apache的proxy(代理)模块可以实现双向代理,功能非常强大,从连接器的实现原理看,用http-proxy模块实现也是很自然的事情,只需打开tomcat的http功能,然后用apache的proxy代理功能将动态请求交给tomcat处理,而静态数据交给apache自身就可以了。proxy-ajp模块是专门为tomcat整合所开发的,通过ajp协议专门代理对tomcat的请求。根据官方的测试,proxy-ajp的执行效率要比http-proxy高,因此在Apache2.2以后的版本,用proxy-ajp模块作为apache和tomcat的连接器是个不错的选择。
需要说明的是,这些连接功能的实现,都是通过在apache中加载相应的功能模块实现,比如上面提到的mod_jk、mod_jk2、proxy-ajp模块,都要事先通过源码编译出对应的模块,然后通过apache配置文件动态加载,实现连接器功能。这点也是apache的优势所在。
三、 Apache与tomcat以及JK模块的安装
CentOS release 5.8 (Final)
1、安装apache
软件下载:http://www.apache.org/dist/httpd/ http://pan.baidu.com/s/1i3DsKrb
[root@localhost ~]# tar zxf httpd-2.2.27.tar.gz
[root@localhost ~]# cd httpd-2.2.27
[root@localhost httpd-2.2.27]# ./configure --prefix=/usr/local/apache2 \
> --enable-modules=all \
> --enable-mods-shared=all \
> --enable-proxy \
> --enable-proxy-connect \
> --enable-proxy-ftp \
> --enable-proxy-http \
> --enable-proxy-scgi \
> --enable-proxy-ajp \
> --enable-proxy-balancer \
> --enable-static-support \
> --with-included-apr \
> --enable-cache \
> --enable-file-cache \
> --with-mpm=prefork \
> --enable-ssl=shared \
> --enable-deflate=shared \
> --enable-expires=shared \
> --enable-headers=shared \
> --enable-rewrite=shared \
> --enable-so
[root@localhost httpd-2.2.27]# make && make install
apache的安装路径为/usr/local/apache2,“--enable-modules=most”表示将大部分模块静态编译到httpd二进制文件中,“--enable-mods-shared=all”表示动态加载所有模块,如果去掉-shared话,是静态加载所有模块。
2、安装JDK
在tomcat运行环境下,JDK是必不可少的软件,因为tomcat只是一个Servlet/JSP容器,底层的操作都需要JDK来完成。
JDK的安装也非常简单,只需到http://java.sun.com/ http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html
下载jdk-7u71-linux-x64.rpm:http://pan.baidu.com/s/1mgLuhr6
此处使用:RPM包安装@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@2
[root@localhost ~]# rpm -ivh jdk-7u71-linux-x64.rpm
Preparing... ########################################### [100%]
1:jdk ########################################### [100%]
Unpacking JAR files...
rt.jar...
jsse.jar...
charsets.jar...
tools.jar...
localedata.jar...
jfxrt.jar...
[root@localhost ~]#
[root@localhost ~]# vim /etc/profile
PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:${JAVA_HOME}/bin"
JAVA_HOME=/usr/java/jdk1.7.0_71
JRE_HOME=${JAVA_HOME}/jre
CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
[root@localhost ~]# source /etc/profile
[root@localhost ~]# java -version 查看是否安装成功
java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b14)
Java HotSpot(TM) 64-Bit Server VM (build 24.71-b01, mixed mode)
从上面输出可以看出,JDK在我们的linux下运行正常。并且版本为build 1.7.0_71-b14。
3、安装tomcat
方法@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
下载apache-tomcat-7.0.56.tar.gz:http://pan.baidu.com/s/1gdDwQbT
http://tomcat.apache.org/download-70.cgi
Tomcat的官方地址http://jakarta.apache.org/
这里以二进制方式安装,我们只需下载对应的二进制版本即可,这里使用的版本是apache-tomcat-7.0.56.tar.gz,下载后的压缩包文件为apache-tomcat-7.0.56.tar.gz,把此安装包放到/usr/local目录下,通过解压即可完成tomcat的安装。
wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-7/v7.0.56/bin/apache-tomcat-7.0.56.tar.gz
[root@localhost ~]# tar zxf apache-tomcat-7.0.56.tar.gz
[root@localhost ~]# mv apache-tomcat-7.0.56 /usr/local/
[root@localhost ~]# vim /etc/profile
export TOMCAT_HOME=/usr/local/apache-tomcat-7.0.56/
[root@localhost ~]# source /etc/profile
[root@localhost ~]# /usr/local/apache-tomcat-7.0.56/bin/startup.sh
验证ip地址:8080出现界面即可
http://192.168.7.109:8080/ --浏览器中打开测试
4、安装JK模块
为了更灵活的使用mod_jk连接器,这里我们采用源码方式编译出所需要的JK模块,JK的源码可以从这个地址去下载,http://archive.apache.org/dist/jakarta/tomcat-connectors/jk/source/,但是不保证此连接永久有效,这里采用的JK版本为jakarta-tomcat-connectors-1.2.14.1 (下载地址为http://pan.baidu.com/s/1jGDqG6M)
[root@localhost ~]# wget http://archive.apache.org/dist/jakarta/tomcat-connectors/jk/source/jakarta-tomcat-connectors-current-src.tar.gz
[root@localhost ~]# tar zxf jakarta-tomcat-connectors-current-src.tar.gz
[root@localhost ~]# cd jakarta-tomcat-connectors-1.2.14.1-src/jk/native/
[root@localhost native]# chmod +x buildconf.sh
[root@localhost native]# ./buildconf.sh
rm autom4te.cache
libtoolize --force --automake --copy
aclocal
autoheader
automake -a --foreign --copy
autoconf
rm autom4te.cache
[root@localhost native]# ./configure --with-apxs=/usr/local/apache2/bin/apxs #apache安装目录中apxs的位置
[root@localhost native]# make && make install
[root@localhost native]# cd apache-2.0/
[root@localhost apache-2.0]# ls
bldjk.qclsrc Makefile Makefile.apxs.in Makefile.vc mod_jk.c mod_jk.la mod_jk.o NWGNUmakefile
config.m4 Makefile.apxs Makefile.in mod_jk.a mod_jk.dsp mod_jk.lo mod_jk.so
[root@localhost apache-2.0]# ls -l /usr/local/apache2/modules/mod_jk.so
-rwxr-xr-x 1 root root 571980 Oct 20 00:56 /usr/local/apache2/modules/mod_jk.so
可以看到有mod_jk.so文件生成,这就是我们需要的JK连接器,默认情况下JK模块会自动安装到/usr/local/apache2/modules目录下,如果没有自动安装到此目录,手动拷贝此文件到modules目录即可。
四、 apache与tomcat整合配置
vim /usr/local/apache2/conf/httpd.conf
添加以下内容:
<IfModule prefork.c>
StartServers 10
MinSpareServers 10
MaxSpareServers 20
ServerLimit 256
MaxClients 256
MaxRequestsPerChild 4000
</IfModule>
<IfModule worker.c>
StartServers 100
MaxClients 1000
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 256
MaxRequestsPerChild 8000
</IfModule>
<Location /project_name>
SetHandler server-status
Order deny,allow
Deny from all
Allow from all
</Location>
<Proxy balancer://cluster>
BalancerMember ajp://127.0.0.1:8009 loadfactor=1
BalancerMember ajp://127.0.0.1:8019 loadfactor=1
BalancerMember ajp://127.0.0.1:8029 loadfactor=1
#ProxySet lbmethod=bytraffic
</Proxy>
ProxyPass /GMServer/ balancer://cluster/GMServer/
修改监听端口:Listen 8000