首页 > 代码库 > 整合apache和tomcat构建Web服务器

整合apache和tomcat构建Web服务器

一、  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

本文出自 “林子” 博客,谢绝转载!

整合apache和tomcat构建Web服务器