Tomcat集群配置笔记 ( by quqi99 )
作者:张华 发表于:2011-04-06
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明
( http://blog.csdn.net/quqi99 )
h1 { margin-top: 0.6cm; margin-bottom: 0.58cm; line-height: 200%; page-break-inside: avoid; }h1.western { font-family: "Times New Roman",serif; font-size: 22pt; }h1.cjk { font-family: "Arial Unicode MS"; font-size: 22pt; font-style: normal; font-weight: bold; }h1.ctl { font-size: 22pt; font-weight: bold; }h1.样式-标题-1- + -四号-western { font-family: "Times New Roman",serif; font-size: 14pt; line-height: 150%; }h1.样式-标题-1- + -四号-cjk { font-family: "Arial Unicode MS"; font-style: normal; font-weight: bold; line-height: 150%; }h1.样式-标题-1- + -四号-ctl { font-size: 22pt; font-weight: bold; line-height: 150%; }p { margin-bottom: 0.21cm; }a:link { color: rgb(0, 0, 255); }
一.
环境说明
1.
服务器3
台,一台安装apache
服务,两台安装tomcat
2.
使用到的各个组件及下载地址:
apache_2.2.11-win32-x86-no_ssl.msi
http://httpd.apache.org/download.cgi
tomcat
6
压缩版
http://tomcat.apache.org/download-60.cgi
apache
的JK
连接器(Windows
版本),作为apache
的一个module
,网站同时提供了配置文件的使用方法
mod_jk-1.2.28-httpd-2.2.3.so
http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.28/
3.ip
配置
一台安装apache
的ip
为192.168.1.50
,两台安装tomcat
的ip
分别为192.168.1.24
和192.168.1.52
(根据各自情况分配)
二.安装过程
1.
在两台安装tomcat
的机器上安装jdk6
(至少jdk5
)
2.
配置jdk
的安装路径,
在环境变量path
中加入jdk
的bin
路径,
新建环境变量JAVA_HOME
指向jdk
的安装路径
3.
安装tomcat
,并测试tomcat
的启动是否正常
http://192.168.1.24:8080
http://192.168.1.50:8080
三.负载均衡配置过程
1.
在192.168.1.50
机器上安装apache
服务,我的安装路径默认为:D:/Program
Files/Apache Software Foundation/Apache2.2
2.
安装完成后测试能否正常启动,http://192.168.1.50
,如图所示:
3.
将mod_jk-1.2.28-httpd-2.2.3.so
拷贝到apache
的modules
目录下
2.
修改apache
的配置文件
httpd.cof
,在最后加上下面这段话:
LoadModule
jk_module modules/mod_jk-1.2.28-httpd-2.2.3.so #
载入jk
连接器
JkWorkersFile
conf/workers.properties #
设置负载均衡的配置文件,即定义均衡规则
JkLogFile
logs/mod_jk.log #
指定日志文件
JkLogLevel
debug #
指定日志级别
#
配置apache
将哪些请求转发给JK
进行均衡
JkMount
/*.jsp loadbalancer
JkMount
/test/* loadbalancer
3.
分别修改两个tomcat
的配置文件conf/server.xml
文件
修改前:
<!--
An Engine represents the entry point (within Catalina) that processes
every
request. The Engine implementation for Tomcat stand alone
analyzes
the HTTP headers included with the request, and passes them
on
to the appropriate Host (virtual host).
Documentation
at /docs/config/engine.html -->
<!--
You should set jvmRoute to support load-balancing via AJP ie :
<Engine
name="Catalina" defaultHost="localhost"
jvmRoute="jvm1">
-->
<Engine
name="Catalina" defaultHost="localhost">
修改后:
<!--
An Engine represents the entry point (within Catalina) that processes
every
request. The Engine implementation for Tomcat stand alone
analyzes
the HTTP headers included with the request, and passes them
on
to the appropriate Host (virtual host).
Documentation
at /docs/config/engine.html -->
<!--
You should set jvmRoute to support load-balancing via AJP ie : -->
<Engine
name="Catalina" defaultHost="localhost"
jvmRoute="node1">
<Engine
name="Catalina" defaultHost="localhost" >
将其中的jvmRoute="jvm1"
分别修改为jvmRoute="node1"
和jvmRoute="node2"
4.
在apache
的conf
目录下创建workers.property
文件,输入以下内容:
#
fine the communication channel
#
定义负载均衡的所有主机名,和前面tomcat
配置文件的JVMroute
属性相对应
#
其中的loadbalancer
是虚拟的主机,负责负载均衡,姑且当成是apache
本身
worker.list=node1,node2,loadbalancer
#
node1
使用AJP
与JK
通讯
worker.node1.port=8009
#
工作端口,若没占用则不用修改
worker.node1.host=192.168.1.24
# node1
的地址为localhost
,如果tomcat
在其他服务器则输入该服务器的地址
worker.node1.type=ajp13
#
类型
worker.node1.lbfactor=100
#
负载平衡因数
worker.node2.port=9009
#
工作端口,若没占用则不用修改
worker.node2.host=192.168.1.52
#node2
服务器的地址
worker.node2.type=ajp13
#
类型
worker.node2.lbfactor=100
#
负载因子,值越大则JK
分发到此tomcat
的负荷越多
#
定义loadbalancer
类型为“负载均衡器(lb
)”
worker.loadbalancer.type=lb
#
定义loadbalancer
进行负载均衡的对象
worker.loadbalancer.balanced_workers=node1,node2
worker.loadbalancer.sticky_session=false
worker.loadbalancer.sticky_session_force=false
5.
在两个tomcat
的安装目录中的webapps
建立相同的应用,我的应用名为test
,在两个应用目录中建立相同
WEB-INF
目录和页面test.jsp
的页面内容如下
<%@
page
language
=
"java"
contentType
=
"text/html;
charset=ISO-8859-1"
pageEncoding
=
"GBK"
%>
<!
DOCTYPE
html
PUBLIC
"-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd"
>
<
html
>
<
head
>
<
meta
http-equiv
=
"Content-Type"
content
=
"text/html;
charset=ISO-8859-1"
>
<
title
>
helloapp
</
title
>
</
head
>
<
body
>
<%
System.out.println(
"call
test.jsp"
);
//
在Tomcat
控制台上打印一些跟踪数据
%>
SessionID:
<%=
session.getId()
%>
</
body
>
</
html
>
6.
重启
apache
服务器和两个
tomcat
服务器,到此负载均衡已经配置完成,测试负载均衡:
http://192.168.1.50/test/test.jsp
,
运行正常则已建立负载均衡
四.集群配置
1.
负载均衡的条件下配置tomcat
集群
2
.分别修改两个tomcat
的配置文件conf/server.xml,
修改内容如下
修改前:
<!--
<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"
bind
=
"192.168.1.100"
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
>
注意:bind
是tomcat
服务器所在的机器的ip
地址
3.
重启两个tomcat
,到此tomcat
的集群配置完成
五.应用配置
对于要进行负载和集群的的tomcat
目录下的webapps
中的应用中的WEB-INF
中的web.xml
文件要添加如下一句配置
<distributable/>
配置前:
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
<
web-app
id
=
"WebApp_ID"
version
=
"2.4"
xmlns
=
"http://java.sun.com/xml/ns/j2ee"
xmlns:xsi
=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation
=
"http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
<
display-name
>
test
</
display-name
>
<
distributable
/>
<
welcome-file-list
>
<
welcome-file
>
index.
html
</
welcome-file
>
<
welcome-file
>
index.
htm
</
welcome-file
>
<
welcome-file
>
index.
jsp
</
welcome-file
>
<
welcome-file
>
default.
html
</
welcome-file
>
<
welcome-file
>
default.
htm
</
welcome-file
>
<
welcome-file
>
default.
jsp
</
welcome-file
>
</
welcome-file-list
>
</
web-app
>
六.测试集群
重新启动apache
服务器和两个tomcat
服务器,输入地址:http://192.168.1.50/test/test.jsp
运行结果如下:
如果同一个浏览器的sessionID
不变,则集群配置成功
分享到:
相关推荐
MTK平台的多功能下載軟件,適用所有MTK手機....
用directshwo开发的视屏播放器,比较简单,有时候会出错
国内最好的数据库达梦DM8,曲奇网盘下载链接:https://quqi.com/s/1243222/wcOZdaWgUlHrwhOk
机械设计同轴剥皮机sw18可编辑非常好的设计图纸100%好用.zip
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Honeywell BR-310 条形码扫描器手册
中国诗词APP「西窗烛」产品需求文档
当然可以!Unity开发是一个非常受欢迎的游戏开发工具,适合初学者入门。以下是一些Unity开发的教程,供您参考: 1. Unity官方文档:Unity官方网站提供了详细的文档和教程,包括Unity的基本概念、工具使用、场景编辑、游戏逻辑编写等。您可以根据自己的需求和水平选择相应的教程。 2. Unity官方的Unity Creator在线课程:Unity Creator是Unity的在线教育平台,提供了许多免费的Unity Creator教程和课程,适合初学者入门。您可以根据教程的内容和难度选择适合自己的课程。 3. Unity中文社区:Unity中文社区是一个非常活跃的社区,提供了许多Unity开发的教程和资源。您可以搜索相关的教程和资源,与其他开发者交流和学习。 4. Unity教程网站:有许多网站提供了Unity开发的教程和资源,如游戏学院、编程教室等。这些网站提供了许多基础和进阶的Unity开发教程,适合初学者和有一定基础的开发者。 5. Unity插件开发:Unity插件开发是Unity开发的一个重要方向,适合有一定基础的开发者。您可以学习如何创建自定义的Unity插件,
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
惠普服务器安装说明
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
附件是一个简单的烟花效果的代码示例。 在Python中,可以使用多种方式来模拟烟花效果,其中一种常用的方法是使用turtle模块,它提供了一个画布和一个小海龟,可以用来绘制各种图形。 这段代码首先导入了turtle模块和random模块,然后在屏幕上绘制了10次烟花爆炸的效果。每次爆炸都是由5个小圆组成,颜色随机选择,圆的大小也是随机的。 请注意,这段代码需要在支持turtle模块的Python环境中运行,并且需要有图形界面的支持。如果你在没有图形界面的环境中(比如某些服务器或者命令行界面),这段代码可能无法正常运行。
基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip基于MATLAB和Simulink通过正运动学和逆运动学设计了PID控制器.zip
基于深度学习的声学回声消除基线代码 # 数据准备 按照以下文件结构,放好语音,我直接使用的是AEC-Challenge 数据集中的合成数据集 ```angular2html └─Synthetic ├─TEST │ ├─echo_signal │ ├─farend_speech │ ├─nearend_mic_signal │ └─nearend_speech ├─TRAIN │ ├─echo_signal │ ├─farend_speech │ ├─nearend_mic_signal │ └─nearend_speech └─VAL ├─echo_signal ├─farend_speech ├─nearend_mic_signal └─nearend_speech ``` 数据处理脚本为 `data_preparation.py`
Dell Edge Gateway 3002 安装和操作手册
88888888888.mp3
环境说明: 开发语言:java 框架:springboot,vue JDK版本:JDK1.8 数据库:mysql5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat11+ 开发软件:idea/eclipse(推荐idea) Maven包:Maven3.3.9+
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。