问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

tomcat6.0怎么修改配置文件server.xml以便启用Ajp13

发布网友 发布时间:2022-04-21 20:21

我来回答

2个回答

热心网友 时间:2022-04-21 22:59

你看看这个:
tomcat6_apache2.2_ajp负载均衡加集群实战
环境:
--------------------------------------------
一台apache2.2服务器,三台tomcat服务器:

apache2.2服务器
1.ip:192.168.1.20
2.只装apache软件:httpd-2.2.6.tar.bz2
安装路径:/usr/local/apache2

tomcat服务器:均配置相同的应用。
1.集群名:balancer://tomcatcluster
2.三台集群服务器ip:
IP_1:192.168.1.31
IP_2:192.168.1.32
IP_3:192.168.1.33
3.测试应用程序test文件夹放在tomcat6的webapps目录下

操作系统均为:centos 4.5_x86
jre:1.6:jdk-6u1-linux-i586-rpm.bin
tomcat6.0:编译好的二进制软件包apache-tomcat-6.0.13.tar.gz
tomcat6.0 安装路径:/usr/local/tomcat6

oralce的jdbc:class12.jar

软件包存放的路径:/home/xiutuo/software/
java安装路径:/usr/java/jdk1.6.0_01
使用普通用户:xiutuo来启动tomcat6
tomcat6开机自动启动脚本:/etc/init.d/tomcat

下载路径:
http://java.sun.com/javase/downloads/index.jsp
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++

一:前言:

1.apache对tomcat集群支持有俩种方式:

a.通过apache2.1之后版本后内置的proxy_ajp。
b.对于apache2.1之版本则通过tomcat的jk2.0.4的mod_jk2.so:
(该版本已经停止开发)
将解压缩后的目录中的moles目录中的mod_jk2.so
文件复制到apache的安装目录下的moles目录中。
********************
俩种方式比较:
proxy_ajp配置较简单,主要表现在proxy_ajp目前只支持配置到目录,
还不支持对文件名称的pattern模式匹配
(即还不能定义到只对jsp文件起作用)。

而jk2则可配置性强,但已经停止开发
********************

官方对ajp和jk2说明:
JK2 has been put in maintainer mode and no further development will take place.
The reason for shutting down JK2 development was the lack of developers interest.
Other reason was lack of users interest in adopting JK2,
caused by configuration complexity when compared to JK.

The latest official JK2 release is 2.0.4.

JK2 will have it's successor within core Apache2.1/2.2 distribution.
We have developed new proxy_ajp that is an addition to the mod_proxy
and uses Tomcat's AJP protocol stack. It is developped in httpd-2.1
and integrated in it. We have also developed a new proxy_balancer
mole for load balancing http and ajp protocol stacks.

JK will be fully supported for all other web servers.
The next JK release is planned for the end of November.
Lots of code from JK2 has been ported to JK

2.tomcat集群方式:
a.DeltaManager
--现在采用的该方式:内部机器集群少采用
b.BackupManager
********************
两种集群方式官方说明:
using the DeltaManager to replicate session deltas.
By all-to-all we mean that the session gets replicated to
all the other nodes in the cluster. This works great for smaller cluster
but we don't recommend it for larger clusters(a lot of tomcat nodes).
Also when using the delta manager it will replicate to all nodes,
even nodes that don't have the application deployed.

To get around this problem, you'll want to use the BackupManager.
This manager only replicates the session data to one backup node,
and only to nodes that have the application deployed.Downside of
the BackupManager: not quite as battle tested as the delta manager.
********************

3.负载均衡(load-balance)定义:
在服务器端短时间内获得大量的请求,单一服务器无法在一个较短的时间内响应这些请求,
此时服务器需要一个机制,请求按照多个服务器不同的负载能力,把这些请求合理的分配。

4.集群(cluster):
在多个服务器之间共享用户信息,资源等。

tomcat6_apache2.2负载均衡加集群:高可用性至高体现。
现在的带集群功能相关软件oracle10g,mysql5,tomcat等。

二:软件安装

1.apache服务器安装:
这里主要介绍apache2的源码安装
# cd /home/xiutuo/software/
# tar -zvxf httpd-2.2.6.tar.gz
# cd httpd-2.2.6
# mkdir -p /usr/local/apache2
# ./configure \
--prefix=/usr/local/apache2 \
--enable-moles=so \
--enable-mods-shared=all \
--enable-proxy \
--enable-proxy-connect \
--enable-proxy-ftp \
--enable-proxy-http \
--enable-proxy-ajp \
--enable-proxy-balancer

注释:这里测试用,编译了所有可用模块,并激活了tomcat集群需要的
enable-proxy,enable-proxy-http,enable-proxy-connect,enable-proxy-ajp
和enable-proxy-balancer,其中proxy-ajp和proxy-balancer必须依赖proxy,
如果是自定义的编译除了以上几个必须的模块外,mod_status也要编译进去,切记。
enable-proxy-ftp可以不编译。
# make
# make install

2. 三台tomcat服务器安装

主要介绍jdk1.6u1和tomcat6的安装,三台机器重复此工作就可以了,
当然记得ip一定要设置正确。

jdk1.6安装
-------------------------------
a.卸载系统自带jdk
# rpm -e j2sdk-1.4.1-fcs

b.安装新jdk
# cd /home/xiutuo/software
进入软件包存放目录

# chmod a+x jdk-6u1-linux-i586-rpm.bin
使它有执行权限

# ./jdk-6u1-linux-i586-rpm.bin
多敲几个空格,然后看到[yes]的时候输入yes,回车
然后在当前目录下就生成了jdk-6u1-linux-i586-rpm

# rpm -ivh jdk-6u1-linux-i586-rpm

c.设置环境变量
仅设置某个用户而不是所有用户可以修改~/.cshrc,~/.bash_profile文件,
追加下面一段,如果为所有用户以及以后添加的用户都加上环境变量的话,
追加/etc/profie文件.
***主意不要在profile和~/.cshrc或~/.bash_profile中重复追加**

这里:
# vi /etc/profile
//java
//如果你安装的j2sdk的路径不一样,请自行修改

JAVA_HOME=/usr/java/jdk1.6.0_01
export JAVA_HOME
CLASSPATH=/usr/java/jdk1.6.0_01/lib:/usr/java/jdk1.6.0_01/jre/lib
export CLASSPATH
PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin
export PATH
JRE=/usr/java/jdk1.6.0_01/jre
export JRE

d:立即生效
//如果你修改的是/etc/profile
# source /etc/profile
//如果你修改的是~/.cshrc
# source ~/.cshrc
//如果你修改的是~/.bash_profile
# source ~/.bash_profile

e:测试成功否
# java -version
Java(TM) SE Runtime Environment (build 1.6.0_01-b06)
Java HotSpot(TM) Client VM (build 1.6.0_01-b06, mixed mode, sharing)
看到这个消息,就ok啦
----------------------------------------------

tomcat6安装
tomcat6更详细的安装请看blog上tomcat文章
----------------------------------------------
a.安装tomcat,
# cd /home/xiutuo/software //进入软件包存放目录
# tar -zvxf apache-tomcat-6.0.13.tar.gz //解压
# mv apache-tomcat-6.0.13 /usr/local/tomcat6 //安装

# cd /usr/local/tomcat6/bin/ //进入安装目录
# tar -zvxf jsvc.tar.gz //解压
# cd jsvc-src //进入jsvc-src目录
# autoconf
# ./configure --with-java=/usr/java/jdk1.6.0_01
# configure时切记加java的jdk路径,否则无法使用普通用户开机自动启动tomcat

# make //编译生成jsvc文件
# cp jsvc .. //拷贝jsvc到上级目录
# cd .. //回到上级目录

# cd /usr/local/tomcat6/

//运行下面的命令可以使tomcat以daemon方式运行
# ./bin/jsvc -cp ./bin/bootstrap.jar \
-outfile ./logs/catalina.out \
-errfile ./logs/catalina.err \
org.apache.catalina.startup.Bootstrap

b.配置oralce的jdbc
//拷贝oracle的jdbc到/usr/local/tomcat6/lib目录下
# cp /home/software/class12.jar ./lib/

c.配置tomcat用户
# cd /usr/local/tomcat6/conf
# vi tomcat-users.xml
内容如下:
<?xml version='1.0' encoding='utf-8'?>
<tomcat-users>
<role rolename="tomcat"/>
<role rolename="role1"/>
<role rolename="manager"/>
<role rolename="admin"/>
<user username="tomcat" password="tomcat" roles="tomcat"/>
<user username="role1" password="tomcat" roles="role1"/>
<user username="both" password="tomcat" roles="tomcat,role1"/>
<user username="admin" password="admin" roles="admin,manager"/>
</tomcat-users>
请修改tomcat里所有定义用户的密码:即修改password为自己想要的值。

d.把应用程序文件夹test放到webapps下

3.tomcat负载均衡和集群配置
参考官方配置文档:
http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html
http://tomcat.apache.org/tomcat-6.0-doc/balancer-howto.html

a.tomcat6配置文件server.xml和应用程序的web.xml

**开放负载均衡,默认使用ajp协议时使用8009端口(使用http协议时为8080端口)
**修改tomcat 的 conf/server.xml 的<Engine>(使用ajp协议时配置)

<!-- You should set jvmRoute to support load-balancing via AJP ie :
<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm1">
-->
<Engine name="Catalina" defaultHost="localhost">
改成

<!-- You should set jvmRoute to support load-balancing via AJP ie :
-->
<Engine name="Standalone" defaultHost="localhost" jvmRoute="tomcat1">
<!--
<Engine name="Catalina" defaultHost="localhost">
-->
说明:
第一台tomcat就把jvmRoute="tomcat1"
第二台tomcat就把jvmRoute="tomcat2"
第三台tomcat就把jvmRoute="tomcat3"

**开放集群
**修改tomcat 的 conf/server.xml (使用ajp协议时配置)
在<Engine> 后面或者 <Host>后面简单的加上
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
也可以加上更详细参数的集群配置内容(这是官方默认,请自行修改相关参数):

<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">

<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>

<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="4000"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>

<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>

<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=""/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>

<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>

<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>

***配置应用的web.xml
***在每个webapps应用中,修改配置文件web.xml文件 添加元素<distributable/>
在web.xml文件中<web-app>元素下增加以下内容:
<!--此应用将与群集服务器复制Session-->
<distributable/>
具体修改如下:
修改前:
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
</web-app>
修改后:
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<!--此应用将与群集服务器复制Session-->
<distributable/>
</web-app>

4.配置apache的ajp负载均衡功能,这里请务必启用反向代理。
******************************
至于其中的原理请参考官方文档说明。

正向代理的典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。
正向代理还可以使用缓冲特性(由mod_cache提供)减少网络使用率。

反向代理的典型用途是将防火墙后面的服务器提供给Internet用户访问。
反向代理还可以为后端的多台服务器提供负载平衡,或为后端较慢的服务器提供缓冲服务。
另外,还可以启用高级URL策略和管理技术,从而使处于不同web服务器系统的web页面同时
存在于同一个URL空间下。
*****************************

参考文档:
tomcat6官方文档
http://tomcat.apache.org/tomcat-6.0-doc/balancer-howto.html
apache中文版本
http://man.chinaunix.net/newsoft/ApacheMenual_CN_2.2new/mod/mod_proxy.html
http://man.chinaunix.net/newsoft/ApacheMenual_CN_2.2new/mod/mod_proxy_balancer.html
apache官方英文版本
http://httpd.apache.org/docs/2.2/mod/mod_proxy.html
http://httpd.apache.org/docs/2.2/mod/mod_proxy_balancer.html

***配置apache
***修改/usr/local/apache2/conf/httpd.conf文件

确保将以下Mole的注释去掉
LoadMole proxy_mole moles/mod_proxy.so
LoadMole proxy_connect_mole moles/mod_proxy_connect.so
LoadMole proxy_ftp_mole moles/mod_proxy_ftp.so
LoadMole proxy_http_mole moles/mod_proxy_http.so
LoadMole proxy_ajp_mole moles/mod_proxy_ajp.so
LoadMole proxy_balancer_mole moles/mod_proxy_balancer.so
LoadMole status_mole moles/mod_status.so

并在最后面,增加
<Location /server-status>
SetHandler server-status
Order Deny,Allow
Deny from all
Allow from all
</Location>
<Location /balancer-manager>
SetHandler balancer-manager
Order Deny,Allow
Deny from all
Allow from all
</Location>
ProxyRequests Off
ProxyPass /test balancer://tomcatcluster/ stickysession=jsessionid nofailover=On

<Proxy balancer://tomcatcluster>
BalancerMember ajp://192.168.1.30:8009 loadfactor=1
BalancerMember ajp://192.168.1.31:8009 loadfactor=2
BalancerMember ajp://192.168.1.32:8009 loadfactor=3
</Proxy>
注释:
ProxyRequests Off 表示启用反向代理。
ProxyPass为代理转发的Url,即将所有访问/的请求转发到
群集balancer://tomcatcluster,这里为/test即将所有访问/的请求转发到群集balancer://tomcatcluster的/test目录

BalancerMember为群集的成员,
即群集服务器1或2或3,负载均衡服务器会根据均衡规则来将请求转发给BalancerMember。

配置好后,启动Apahce服务器,访问localhost就会看到群集服务器中应用返回的结果。

访问http://192.168.1.20/balancer-manager,显示负载均衡有关信息

5.调试负载均衡集群系统

调试前务必:
先开启三台tomcat6服务器的tomcat服务!
再开启apache服务器的apache服务,切记!

a.开启tomcat服务
# cd /usr/local/tomcat6/bin
# ./shutdown.sh //停止tomcat
# ./start.sh //启动tomcat

查看tomcat的进程:
# ps -e | grep java
出现了java这个进程的话,说明你的tomcat起来了。

b.开启apache服务
# cd /usr/local/apache2/bin
# ./apachectl configtest
//命令检查一下配置是否有误,显示Syntax OK,说明配置正确
# ./apachectl stop //停止apache
# ./apachectl start //启动apache

6.检验是否负载均衡集群系统成功

访问apache服务器的web服务
http://192.168.1.20/balancer-manager
如果显示负载均衡有关信息则说明成功了。
接着可以访问http://192.168.1.20/test即访问到了tomcat的test应用

7.具体的tomcat集群负载均衡优化请参考文档自行设置相关参数
具体的apache优化请参考文档自行设置相关参数

热心网友 时间:2022-04-22 00:17

上面写的够全的...
tomcat6.0怎么修改配置文件server.xml以便启用Ajp13

请修改tomcat里所有定义用户的密码:即修改password为自己想要的值。d.把应用程序文件夹test放到webapps下3.tomcat负载均衡和集群配置参考官方配置文档:http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.htmlhttp://tomcat.apache.org/tomcat-6.0-doc/balancer-howto.htmla.tomcat6配置文件server.xml和应用程序...

JSP开发环境配置

tomcat最主要的配置文件就是server.xml(在 tomcat安装路径\conf文件夹下面) 在此文件里 &lt;Context path="" docBase="你存放JSP文件的目录"debug="0" reloadable="true" crossContext="false"&gt; &lt;/Context&gt; 在conf目录下同时建立一个workers.properties文件 里面内容是 workers.tomcat_home=C:\Tomcat(to...

如何解决apache tomcat http

1、配置Tomcat查找Tomcat目录下的 conf/server.xml文件,在&lt;host&gt;&lt;/host&gt;中间加入以下语句以修改其默认的目录:&lt;Context path="" docBase="E:\wwwroot" reloadable="true" crossContext="true"/&gt;在这里,如果 path 不为空,则设置的是虚拟目录,path 的值为虚拟目录名。查找Tomcat目录下的 conf/workers.properties文...

tomcat6运行后打开http://localhost:8080无法显示该页

信息: Find registry server-registry.xml at classpath resource 2009-3-26 17:40:03 org.apache.catalina.startup.Catalina start 信息: Server startup in 2828 ms === 像我这里,第2行,就是tomcat启动的端口,8080;第4行,是tomcat关闭的端口,8009;...

CentOS5.3 - mysql-6.0.10-alpha 源代码和设置

_timeout=300 --- 我的tomcat 配置文件路径: /usr/local/tomcat/conf/server.xml 最后编辑Tomcat的配置文件server.xml,在 &lt;Host 段中加入: &lt;Context path="" docBase="/usr/local/apache2/htdocs" debug="0" reloadable="true" crossContext="true"/&gt; 重新启动Apache和Tomcat。。。 [root@localhost bin]...

如何在服务器上配置Tomcat和JDK

首先需要做以下准备工作 1、安装好 Tomcat 和 IIS6,并且都能正常运行 2、Tomcat的端口没做任何修改 3、下载集成需要的文件 -apache-tomcat-5.5.25.exe -jdk-1_5_0_13-windows-i586-p.exe -isapi_redirector2.rar 集成步骤 1、配置环境变量 JAVA_HOME 和 TOMCAT_HOME 2、将 isapi_redirector2...

jsp 在域名中去掉8080

1、安装jdk,详细操作请参考本站windows 2k和redhat 8.0下java环境配置 2、如何修改端口号 使用文本编辑器如EditPlus,打开server.xml文件,查找到 &lt;!-- Define a non-SSL Coyote HTTP/1.1 Connector on port 8080 --&gt; &lt;Connector className="org.apache.coyote.tomcat4.CoyoteConnector" port="8080" minProcessors...

RecvfailureConnectionwasreset

(指出mod_jk模块工作所需要的工作文件workers.properties的位置) JkMount /servlet/* ajp13 JkMount /*.jsp ajp13 (将所有servlet 和jsp请求通过Ajp13的协议送给Tomcat,让Tomcat来处理) 3)添加完毕后保存。 7、 配置Tomcat 用文本编辑器打开f:Tomcat4confserver.xml。因为Tomcat4默认不启用Ajp13,所以查找到如下这段代...

...2.2.3与最新版本的tomcat6.0.2的整合配置应该怎么作?我搞了老板天...

JkMount /*.jsp ajp13 3. 查看C:\Tomcat 5.0\conf\server.xml文件中有关端口“8009”是否被注释,如果是和我这的版本一致的话,不用修改。4. 在C:\Tomcat 5.0\conf\目录下,新建文件名为“workers.properties”的文件,将如下内容复制到新建文件workers.properties中。CODE: [Copy to clipboard]...

windows环境下的tomcat集群怎么搭建

1、安装tomcat+apache+mysql。2、修改tomcat的端口,即修改server.xml中的配置,并修改 &lt;Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat_8084"&gt; 3、修改httpd.conf,解注释Include conf.d/*.conf 4、在conf.d文件夹中加入xxx.conf文件,在该文件中添加如下配置:LoadModule proxy_...

tomcat配置文件改端口 tomcat server 配置 tomcat的配置文件在哪里 tomcat的配置文件详解 tomcat配置文件调整 tomcat配置文件路径 tomcat配置文件信息 tomcat核心配置文件 tomcat数据库配置文件
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
平阴县第一中学建校背景 平阴新一中初中新生应该准备什么东西? 2010年平阴新一中高中一年学费多少钱 平阴新一中往年试题,求,近期用,加招生计划!!!瞎答者S!!!请在两天内解 ... 硬盘格式化分区 硬盘ssd和hhd混合用 两个盘都要分区 在分区的时候 4k对... 硬盘功耗:固态与机械谁更耗电? ...块现象?它是怎么拼出来的?大学某老师说谷歌地图是人为P的..._百度... 使用usb分线器连接鼠标,usb optical mouse安装失败,(直接插电脑上的时候... 我用带芯片的USB数据线连接2个电脑,已经安装了数据线的驱动了,现在想让... 请问,从真南路1051弄到澳门路519号怎么走? 日食和月食分别是什么 tomcat远程管理端口怎么用 日食和月食形成的动画日食和月食是怎样形成的,主要 一个tomcat可以同时绑定本机ip和物理ip吗 能给我讲解一下日食和月食吗? 怎么修改tomcat服务器的默认的8080端口 日食月食的物理原理是什么如题 日食和月食的原理分别是什么 linux tomcat shutdown端口可以关闭吗 求日食与月食的原理、特点、周期等。 s抖音观看历史删除掉怎么可以看到她看过谁 tomcat配置多个http的&lt;Connector&gt;端口不同,... tomcat中&lt;server.xml&gt;用到了很多端口,他们各自有什... 苹果8p抖音观看历史在哪里找? 提车上牌买保险流程 新车如何去买保险,如何挂牌?请告知具体流程 汽车保险流程怎么走 买车后,上保险的流程是怎样的? 行李箱的密码忘了怎么办 箱子密码锁忘记密码怎么办 怎样与学前儿童做一个日食或月食的实验,求步骤 《日食和月食》一课教学可体现什么思想 日食和月食如何记忆可以简单解释一下吗 日食和月食如何记忆 日食和月食怎么记忆 日食和月食的规律与周期是什么? 日食和月食的成像规律 日食与月食的成因画图说明,要详细点 pdf文档如何解除密码限制? pdf如何取消加密 pdf加密文件怎么解密 PDF密码解除怎么解? 为什么冬天适合夜钓钓鲫鱼 pdf文档知道密码,如何取消加密? 冬天夜钓鲫鱼用什么饵? PDF加密如何取消? 如何快速去除PDF文档密码 navicat for mysql怎么新建数据库 冬天夜钓可以钓鲫鱼吗 加密码的PDF文件怎么把密码去掉?密码是知道的