apache整合tomcat.docx

上传人:b****8 文档编号:11385512 上传时间:2023-02-28 格式:DOCX 页数:18 大小:27.49KB
下载 相关 举报
apache整合tomcat.docx_第1页
第1页 / 共18页
apache整合tomcat.docx_第2页
第2页 / 共18页
apache整合tomcat.docx_第3页
第3页 / 共18页
apache整合tomcat.docx_第4页
第4页 / 共18页
apache整合tomcat.docx_第5页
第5页 / 共18页
点击查看更多>>
下载资源
资源描述

apache整合tomcat.docx

《apache整合tomcat.docx》由会员分享,可在线阅读,更多相关《apache整合tomcat.docx(18页珍藏版)》请在冰豆网上搜索。

apache整合tomcat.docx

apache整合tomcat

整合apache和tomcat构建Web服务器

2011-05-1208:

52:

29

标签:

web服务器 整合 tomcat 休闲 apache

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。

否则将追究法律责任。

linux是最常用的web服务器,本节我们将通过整合apache和tomcat构建一个java/jsp运行平台,详细介绍web服务器的搭建过程。

一、 apache与tomcat整合的必要性

Apache是最流行的Web服务器,开放源代码,支持跨平台的应用(可以运行在几乎所有的Linux、Unix、Windows系统平台上),尤其对Linux的支持相当完美。

apache的优点有:

 功能强大,apache自带了很多功能模块,可根据需求编译自己需要的模块。

 配置简单,apache的配置文件非常简单,通过简单的配置可实现强大功能。

 速度飞快,apache处理静态页面文件效率非常高,可以应对大并发和高负荷访问请求。

 性能稳定,apache在高负荷请求下性能表现卓越,执行效率非常高。

但是apache也有自身的缺点:

 只支持静态网页,对于jsp、php等动态网页不支持

 Apache是以进程为基础的结构,进程要比线程消耗更多的系统开支,因此,不太适合于多处理器环境。

Tomcat是Sun和Apache合作做出来的JSPServer,有如下优点:

 支持Servlet和JSP,可以很好的处理动态网页。

 跨平台性好:

Tomcat是Java程序,所以只要有JDK就可以使用,不需要考虑操作系统平台。

但是,tomcat也有自身缺点:

 处理静态页面效率不高:

Tomcat本身可以做为WebServer,但是tomcat在处理静态页面时没有Apache迅速。

 可配置性不强:

tomcat不像Apache一样配置简单,稳定、强壮。

综上所述,通过相互的整合刚好弥补了各自的缺点,通过整合可以实现:

 客户端请求静态页面时,由Apache服务器响应请求。

 客户端请求动态页面时,则是Tomcat服务器响应请求。

 通过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模块支持Apache1.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的优势所在。

在下面的讲述中,我们将重点讲述mod_jk作为连接器的安装配置与实现。

三、 Apache与tomcat以及JK模块的安装

下面以RedHatEnterpriseLinuxServerrelease5操作系统为例,详细介绍apache+tomcat+jk的安装过程。

1.安装apache

Apache目前有几种主要版本,包括1.3.x、2.0.x以及2.2.x等等,在1.3.x以前的版本中通常取名以apache开头,2.x以后版本则用httpd开头来命名。

apache的官方地址为http:

//httpd.apache.org/,这里以源码的方式进行安装,我们下载的版本是Apache2.0.59,下载后的压缩包文件为httpd-2.0.59.tar.gz。

下面是具体的编译安装过程:

[root@webserver~]#tar-zxvf httpd-2.0.59.tar.gz

[root@webserver~]#cdhttpd-2.0.59

[root@webserver~]#./configure--prefix=/usr/local/apache2\

--enable-modules=most\

--enable-mods-shared=all\

--enable-so\

[root@webserver~]#make

[root@webserver~]#makeinstall

Apache安装步骤以及选项的含义已经在第五章有详细的介绍,这里不在详述,这里我们设定apache的安装路径为/usr/local/apache2,“--enable-modules=most”表示将大部分模块静态编译到httpd二进制文件中,“--enable-mods-shared=all”表示动态加载所有模块,如果去掉-shared话,是静态加载所有模块。

2.安装tomcat

Tomcat的官方地址http:

//jakarta.apache.org/ ,这里以二进制方式安装,我们只需下载对应的二进制版本即可,这里使用的版本是tomcat-5.0.30,下载后的压缩包文件为jakarta-tomcat-5.0.30.tar.gz,把此安装包放到/usr/local目录下,通过解压即可完成tomcat的安装。

基本步骤如下:

[root@webserverlocal]#tar-zxvfjakarta-tomcat-5.0.30.tar.gz

[root@webserverlocal]#mvjakarta-tomcat-5.0.30 tomcat5.0.30

由于解压后的目录名字太长,不易操作,因此可以直接将解压后的目录重命名适合记忆的名字,这里我们将jakarta-tomcat-5.0.30重命名为tomcat5.0.30,软件名称加上软件版本的格式便于记忆。

3.安装JDK

在tomcat运行环境下,JDK是必不可少的软件,因为tomcat只是一个Servlet/JSP容器,底层的操作都需要JDK来完成。

JDK的安装也非常简单,只需到

[root@webserver~]#cd /usr/local

[root@webserverlocal]#chmod755jdk-6u7-linux-i586.bin

[root@webserverlocal]#./jdk-6u7-linux-i586.bin

然后根据提示输入“yes”,程序会自动完成安装,安装完毕,会在/usr/local/下产生一个jdk1.6.0_07目录,这个就是JDK的程序目录了。

[root@localhostlocal]#/usr/local/jdk1.6.0_07/bin/java-version

javaversion"1.6.0_07"

Java(TM)SERuntimeEnvironment(build1.6.0_07-b06)

JavaHotSpot(TM)ServerVM(build10.0-b23,mixedmode)

从上面输出可以看出,JDK在我们的linux下运行正常。

并且版本为1.6.0_07。

4.安装JK模块

为了更灵活的使用mod_jk连接器,这里我们采用源码方式编译出所需要的JK模块,JK的源码可以从这个地址去下载,http:

//archive.apache.org/dist/jakarta/tomcat-connectors/jk/,但是不保证此连接永久有效,这里采用的JK版本为jk-1.2.15。

下载后的JK源码压缩包文件为jakarta-tomcat-connectors-current-src.tar.gz,这里也将此压缩包放到/usr/local下,具体安装步骤如下:

[root@webserver~]#cd/usr/local/

[root@webserverlocal]#tarxzvfjakarta-tomcat-connectors-1.2.15-src.tar.gz

[root@webserverlocal]#cdjakarta-tomcat-connectors-1.2.15-src/jk/native

[root@webservernative]#chmod755buildconf.sh

[root@webservernative]#./buildconf.sh

[root@webservernative]#./configure\--with-apxs=/usr/local/apache2/bin/apxs #这里指定的是apache安装目录中apxs的位置

[root@webservernative]#make

[root@webservernative]#makeinstall

[root@webservernative]#cdapache-2.0

[root@webservernative]#llmod_jk.so

-rwxr-xr-x1rootroot477305Oct 908:

49mod_jk.so

可以看到有mod_jk.so文件生成,这就是我们需要的JK连接器,默认情况下JK模块会自动安装到/usr/local/apache2/modules目录下,如果没有自动安装到此目录,手动拷贝此文件到modules目录即可。

四、 apache与tomcat整合配置

本节详细讲述apache和tomcat整合的详细配置过程,这里假定web服务器的IP地址为192.168.60.198,测试的jsp程序放置在/webdata/www目录下,如果没有此目录,需要首先创建这个目录,因为在下面配置过程中,会陆续用到/webdata/www这个路径。

1.创建Tomcatworkers

Tomcatworker是一个服务于webserver、等待执行servlet/JSP的Tomcat实例,创建tomcatworkers需要增加3个配置文件,分别是Tomcatworkers配置文件workers.properties,URL映射文件uriworkermap.properties和JK模块日志输出文件mod_jk.log,mod_jk.log文件会在apache启动时自动创建,这里只需创建前两个文件即可。

(1)tomcatworkers配置文件

定义Tomcatworkers的方法是在apache的conf目录下编写一个名为“workers.properties”的属性文件,使其作为apache的插件来发挥作用,下面讲述workers.properties配置说明。

worker.list用来定义Workers列表,当apache启动时,workers.properties作为插件将初始化出现在worker.list列表中的workers。

定义worker类型的格式:

worker.worker名字.type=

例如:

定义一个名为“tomcat12”的worker,其使用ajp12协议与tomcat进程通讯:

 

  worker.tomcat12.type=ajp12

定义一个名为“tomcat13”的worker,其使用ajp13协议与tomcat进程通讯:

  worker.remote.type=ajp13 

  定义一个名为“tomcatjni”的worker,其使用JNI的方式与tomcat进程通讯

  worker.tomcatjni.type=jni 

  定义一个名为“tomcatloadbalancer”的worker,作为对多个tomcat进程的负载平衡使用:

  worker.tomcatloadbalancer.type=lb

设置worker属性的格式为:

worker.worker名字.属性=

这里只说明ajp13协议支持的几个常用属性:

 Host:

监听ajp13请求的的tomcatworker主机地址

 Port:

tomcatworker主机监听的端口。

默认情况下tomcat在ajp13协议中使用的端口为8009。

 lbfactor:

当tomcat用作负载均衡时,此属性被使用,表示此tomcatworker节点的负载均衡权值。

下面是我们的workers.properties文件内容:

[root@localhost~]#vi/usr/local/apache2/conf/workers.properties

worker.list=tomcat1

worker.tomcat1.port=8009

worker.tomcat1.host=localhost

worker.tomcat1.type=ajp13

worker.tomcat1.lbfactor=1

(2)URL过滤规则文件uriworkermap.properties

也就是URI映射文件,用来指定哪些URL由Tomcat处理,也可以直接在httpd.conf中配置这些URI,但是独立这些配置的好处是JK模块会定期更新该文件的内容,使得我们修改配置的时候无需重新启动Apache服务器。

下面是我们的一个映射文件的内容:

[root@localhost~]#vi /usr/local/apache2/conf/uriworkermap.properties

/*=tomcat1

!

/*.jpg=tomcat1

!

/*.gif=tomcat1

!

/*.png=tomcat1

!

/*.bmp=tomcat1

!

/*.html=tomcat1

!

/*.htm=tomcat1

!

/*.swf=tomcat1

!

/*.css=tomcat1

!

/*.js=tomcat1

在上面的配置文件中,“/*=tomcat1”表示将所有的请求都交给tomcat1来处理,而这个“tomcat1”就是我们在workers.properties文件中由worker.list指定的。

这里的“/”是个相对路径,表示存放网页的根目录,这里是上面假定的/webdata/www目录。

“!

/*.jpg=tomcat1”则表示在根目录下,以“*.jpg”结尾的文件都不由JK进行处理,其它设置含义类似,也就是让apache处理图片、js文件、css文件以及静态html网页文件。

特别注意,这里有个先后顺序的问题,JK模块在处理网页根目录文件的时候,会首先过滤掉不让自己处理的设定,剩下的设定自己全部处理。

例如上面的设定中,JK模块会首先在/webdata/www目录过滤掉所有图片、flash、js文件、css文件和静态网页,将剩下的文件类型自己全部处理。

2.Apache的配置

(1)apache的目录结构

上面我们通过源码方式把apache安装到了/usr/local/apache2下,详细的目录结构如表8.1所示:

表8.1

目录名称 目录作用

bin Apache二进制程序及服务程序目录

lib 库文件目录

conf 主配置文件目录

logs 日志文件目录

htdocs 默认web应用根目录

cgi-bin 默认的cgi目录

modules 动态加载模块目录,上面生成的JK模块,就放在了这个目录下。

manual Apache使用文档目录

man Man帮助文件目录

error 默认的错误应答文件目录

include 包含头文件的目录

icons Apache图标文件目录

(2)apache的配置文件

 /usr/local/apache2/conf/httpd.conf(apache主要配置文件)

httpd.conf是包含若干指令的纯文本文件,配置文件的每一行包含一个指令,指令是不区分大小写的,但是指令的参数却对大小写比较敏感,“#”开头的行被视为注解并被忽略,但是,注解不能出现在指令的后边。

配置文件中的指令对整个web服务器都是有效的。

 /usr/local/apache2/bin/apachectl(apache启动/关闭程序)

可以通过“/usr/local/apache2/bin/apachectlstart/stop/restart”的方式启动/关闭/重启apache进程。

apachectl其实是个shell脚本,它可以自动检测httpd.conf的指令设定,让apache在最优的方式下启动。

 /usr/local/apache2/bin/httpd

httpd是一个启动apache的二进制文件。

 /usr/local/apache2/modules

Apache是模块化的web服务器,所有编译的模块默认都会放到这个目录下,然后可以在httpd.conf文件中指定模块位置,动态加载!

 /usr/local/apache2/logs/access_log 

/usr/local/apache2/logs/error_log

 这两个分别为apache的访问日志文件和错误日志文件,通过监测这两个文件,我们可以了解apache的运行状态。

(3)httpd.conf基本设定

httpd.conf配置文件有3个部分组成,分别是:

全局变量、配置主服务器、配置虚拟主机。

下面我们详解讲述下/usr/local/apache2/conf/httpd.conf文件各个指令的含义。

[root@webserver~]#vi/usr/local/apache2/conf/httpd.conf

全局变量配置部分

ServerRoot"/usr/local/apache2"

ServerRoot用于指定守护进程httpd的运行目录,httpd在启动之后自动将进程的当前目录切换到这个指定的目录下,可以使用相对路径和绝对路径。

PidFilelogs/httpd.pid

PidFile指定的文件将记录httpd守护进程的进程号,由于httpd能自动复制其自身,因此apache启动后,系统中就有多个httpd进程,但只有一个进程为最初启动的进程,它为其他进程的父进程,对父进程发送信号将影响所有的httpd进程。

Timeout300

Timeout用来定义客户端和服务器端程序连接的超时间隔,单位为秒,超过这个时间间隔,服务器将断开与客户端的连接。

KeepAliveOn

KeepAlive用来定义是否允许用户建立永久连接,On为允许建立永久连接,Off表示拒绝用户建立永久连接,例如,要打开一个含有很多图片的页面,完全可以建立一个tcp连接将所有信息从服务器传到客户端即可,而没有必要对每个图片都建立一个tcp连接。

此选项建议设置为On。

MaxKeepAliveRequests100

  MaxKeepAliveRequests用来定义一个tcp连接可以进行HTTP请求的最大次数,设置为0代表不限制请求次数,这个选项与上面的KeepAlive相互关联,当KeepAlive设定为On,这个设置开始起作用。

KeepAliveTimeout15

  KeepAliveTimeout用来限定一次连接中最后一次请求完成后延时等待的时间,如果超过了这个等待时间,服务器就断开连接。

ServerLimit  300

StartServers        5

MinSpareServers     5

MaxSpareServers    20

MaxClients        300

MaxRequestsPerChild 2000

StartServers        2

MaxClients        150

MinSpareThreads    25

MaxSpareThreads    75 

ThreadsPerChild    25

MaxRequestsPerChild 0

上面的两段指令其实是对web服务器的使用资源进行的设置,apache可以运行在prefork和worker两种模式下,可以通过/usr/local/apache2/bin/httpd–l来确定当前apache运行在哪种模式,在编译apache时,如果指定“--with-mpm=MPM”参数,那么apache默认运行在prefork模式下,如果指定的是“--with-mpm=worker”参数,那么默认运行在worker模式下。

如果没有做任何模式指定,那么apache默认也运行在prefork模式下。

prefork采用预派生子进程方式,用单独的子进程来处理不同的请求,进程之间彼此独立。

 StartServers表示在启动apache时,就自动启动的进程数目。

 MinSpareServers设置了最小的空闲进程数,这样可以不必在请求到来时再产生新的进程,从而减小了系统开销以增加性能。

 MaxSpareServers设置了最大的空闲进程数,如果空闲进程数大于这个值,apache会自动关闭这些多余进程,如果这个值设置的比小MinSpareServers,则Apache会自动把其调整为MinSpareServers+1。

 MaxRequestsPerChild设置了每个子进程可处理的最大请求数,也就是一个进程能够提供的最大传输次数,当一个进程的请求超过此数目时,程序连接自动关闭。

0意味着无限,即子进程永不销毁。

这里我们设置为2000,已经基本能满足中小型网站的需要。

 MaxClients设定Apache可以同时处理的请求数目。

是对Ap

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 中考

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1