`

Tomcat6集群 + Apache + Nginx均衡负载及其测试(转)

阅读更多
Tomcat6 集群配置端口规划:注:该端口是在同一台机器上启动2个tomcat,需要修改一下端口不重复,如果一台机器只部署1个tomcat其端口可以一样。

Tomcat6 集群配置端口规划:
注:该端口是在同一台机器上启动2个tomcat,需要修改一下端口不重复,如果一台机器只部署1个tomcat其端口可以一样。

Tomcat6集群配置:
在server.xml中修改:

将:

<Engine name="Catalina" defaultHost="localhost">  

修改为:

<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">  
其中 jvmRoute="jvm1" 在不同的tomcat中名称不一样。

在<Engine></Engine>节点中加入如下内容:

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

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

         <!--

                   <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="5001"

                selectorTimeout="100" 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" />

                   <Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor" />

         </Channel>

         <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"

                       filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;" />

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

</Cluster>
注意在同一台机器上:Receiver 节点端口: port="5001" 要不一样。

优化:
内存优化配置:
Windows:

set JAVA_OPTS = " -server -Xms512M -Xmx2048M -XX:MaxNewSize=256M -XX:PermSize=256M -XX:MaxPermSize=512M -XX:+UseConcMarkSweepGC -XX:+PrintGCDetails  -XX:+PrintGCTimeStamps -Djava.awt.headless=true" 
Linux:

JAVA_OPTS = " -server -Xms512M -Xmx2048M -XX:MaxNewSize=256M -XX:PermSize=256M -XX:MaxPermSize=512M -XX:+UseConcMarkSweepGC  -XX:+PrintGCDetails  -XX:+PrintGCTimeStamps -Djava.awt.headless=true"
其他优化配置:
1、加入如下配置1:
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" />
修改

<Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

               redirectPort="8443" />
为:

<Connector port="8080"  executor="tomcatThreadPool" protocol="HTTP/1.1"

               connectionTimeout="60000"

               enableLookups="false" redirectPort="8443" />
修改:

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

为:

<Connector port="8009" executor="tomcatThreadPool"

               connectionTimeout="60000"

               enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />
2、或者:
修改

<Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

               redirectPort="8443" />
为:

<Connector port="8080"  protocol="HTTP/1.1"

               maxThreads="500"

               acceptCount="50" connectionTimeout="60000"

               enableLookups="false" redirectPort="8443" />
修改:

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
为:

<Connector port="8009"

               maxThreads="500"  connectionTimeout="60000"

               enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />
注:两者的主要区别是:executor被起用且关联时maxThreads="500" 被忽略。

几个属性解释:

maxThreads

Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。 可以根据机器的时期性能和内存大小调整,一般可以在400-500。最大可以在800左右。

acceptCount

  指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。

minSpareThreads

Tomcat初始化时创建的线程数。默认值4。

connnectionTimeout

网络连接超时,默认值20000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。(本系统由于与后台系统接口超时时间较长,使用设置为60000)

enableLookups

是否反查域名,默认值为true。为了提高处理能力,应设置为false

Executor节点

表示Tomcat组件之间共享的线程池。

maxIdleTime

空闲线程被关闭之前的毫秒数。默认值是60000。

Nginx + Tomcat负载均衡配置:
在配置文件

  upstream  tomcat6 {

            server 192.168.100.50:8080  weight=1;

            server 192.168.100.50:8081  weight=1;

  }
其中tomcat6名称随意,注意IP地址和端口。

修改Server节点中location:

    location / {

        root   html;

        index  index.html index.htm;

    }

为:

    location  / {

       #root   html;

       #index  index.html index.htm;

            proxy_pass  http://tomcat6;

    }


注意http://tomcat6中tomcat6名称与上面的配置一样。

Apache + Tomcat 负载均衡配置:
Apache Http Server与Tomcat连接有三种方式,可以参考:

http://www.ibm.com/developerworks/cn/opensource/os-lo-apache-tomcat/index.html

本文只介绍最常用的JK方式,需要2个文件:
1、httpd.conf

Apache 服务器的配置文件,用来加载 JK 模块以及指定 JK 配置文件信息

2、workers.properties

到 Tomcat 服务器的连接定义文件。

下面是一个典型的 httpd.conf 对 JK 的配置:

# (httpd.conf)

# 加载 mod_jk 模块

LoadModule jk_module modules/mod_jk.so

#

# Configure mod_jk

#

JkWorkersFile conf/workers.properties

JkMountFile conf/uriworkermap.properties

JkLogFile logs/mod_jk.log

JkLogLevel warn
mod_jk.so文件可以从http://labs.xiaonei.com/apache-mirror/tomcat/tomcat-connectors/jk/binaries/下载,下载源代码后需要编译,下载二进制后直接复制到apache目录modules文件夹下面,修改上面配置文件LoadModule jk_module modules/mod_jk.so,注意其对应其apache的版本2.0.x和2.2.x,以及不同的平台。一般对于AIX,HP-UX平台已经包含了mod_jk.so文件不需要再下载或编译,HP-UX一般apache目录在/opt/hpws/apache/。

上面配置也可单独拆分为一个单独的文件,建立mod_jk.conf文件加入上面配置内容,在httpd.conf中加入如下内容即可:

Include conf/mod_jk.conf

接下来在 Apache 的 conf 目录下新建文件: workers.properties

worker.list = controller,tomcat1,tomcat2,tomcat3,tomcat4  #server 列表

#========tomcat1========

worker.tomcat1.port=8009         #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat1.host=192.168.1.99  #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat1.type=ajp13

worker.tomcat1.lbfactor = 1   #server的加权比重,值越高,分得的请求越多

#========tomcat2========

worker.tomcat2.port=9009       #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat2.host=192.168.1.99 #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat2.type=ajp13

worker.tomcat2.lbfactor = 1   #server的加权比重,值越高,分得的请求越多

#========tomcat3========

worker.tomcat3.port=8009         #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat3.host=192.168.1.100  #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat3.type=ajp13

worker.tomcat3.lbfactor = 1   #server的加权比重,值越高,分得的请求越多

#========tomcat4========

worker.tomcat4.port=9009       #ajp13 端口号,在tomcat下server.xml配置,默认8009

worker.tomcat4.host=192.168.1.100  #tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat4.type=ajp13

worker.tomcat4.lbfactor = 1   #server的加权比重,值越高,分得的请求越多

#========controller,负载均衡控制器========

worker.controller.type=lb

worker.controller.balanced_workers=tomcat1,tomcat2,tomcat3,tomcat4   #指定分担请求的tomcat

worker.controller.sticky_session=false #worker.controller.sticky_session=1 #此处指定集群是否需要会话复制,如果设为true,则表明为会话粘性,不进行会话复制。
分享到:
评论

相关推荐

    Tomcat6集群 + Apache + Nginx均衡负载及其测试

    Tomcat6集群 + Apache + Nginx 均衡负载 以及apache 的ab进行压力测试的方法

    Nginx+keepalived+tomcat实现性负载均衡(包含需要的包)

    在构建高性能、高可用性的Web服务时,使用Nginx+keepalived+tomcat的组合可以实现强大的负载均衡和故障转移功能。这个方案的核心思想是利用Nginx作为前端反向代理服务器,通过keepalived来确保服务的高可用性,并将...

    redis+tomcat+nginx负载均衡配置

    在构建高性能、高可用性的Web服务时,"redis+tomcat+nginx负载均衡配置"是一个常见且有效的架构模式。这个组合充分利用了各个组件的优势,确保系统稳定、响应快速,并能够处理大量的并发请求。以下是关于这个配置的...

    Nginx+Tomcat+Redis搭建均衡负载集群

    这个架构利用Nginx作为反向代理和负载均衡器,Tomcat作为Java应用服务器处理业务逻辑,而Redis则用作缓存系统以提升数据访问速度。下面我们将详细探讨这些组件的作用及其在集群环境中的配置与协同工作。 **Nginx** ...

    Nginx+Tomcat负载均衡企业实战.docx

    本文档主要介绍了 Nginx+Tomcat 负载均衡的企业实战,涵盖了从0开始构建 Nginx WEB 平台、Tomcat WEB 集群、代码发布、Nginx 负载均衡 Tomcat 集群、动静分离、Rewrite 实战等方面的内容。 一、从 0 开始构建 Nginx...

    keepalived+nginx+tomcat+redis+mysql所需的jdk包

    在构建高性能、高可用性的Web服务环境中,Java开发和运行环境、数据库系统、负载均衡以及缓存服务都是不可或缺的关键组件。这个压缩包包含了"keepalived+nginx+tomcat+redis+mysql"所需的基础组件,特别是Java ...

    Nginx+KeepAlived+Tomcat负载架构

    本文将详细介绍如何通过`Nginx+KeepAlived+Tomcat`构建一个稳定、高效的负载均衡架构。 #### 二、关键技术介绍 ##### 1. Nginx - **简介**:Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)...

    tomcat7+apache2.2集群、负载均衡.rar

    标题中的“tomcat7+apache2.2集群、负载均衡”指的是使用Apache HTTP Server 2.2.16与Tomcat 7.0.41构建的集群环境,通过负载均衡技术来分发请求,提高服务的可用性和响应速度。在这样的集群中,Apache作为前端...

    Apache+Tomcat集群和负载均衡及Session绑定

    【Apache+Tomcat 集群与负载均衡及Session...通过以上配置,Apache+Tomcat集群可以实现高效的负载均衡和高可用性,同时通过Session绑定确保用户会话的连续性。注意定期监控和优化集群性能,以应对不断变化的业务需求。

    nginx+tomcat+redis +redis客户端 等负载均衡资料

    在负载均衡场景下,`nginx`可以作为前端服务器,根据预设策略将进来的网络请求分发到后端多个`tomcat`服务器上,实现流量分散,降低单个服务器的压力,提高系统整体可用性。 `tomcat`是Apache软件基金会的Java ...

    nginx-1.11.3+apache-tomcat-7.0.47搭建高性能负载均衡集群

    ### Nginx 1.11.3 + Apache Tomcat 7.0.47 高性能负载均衡集群搭建详解 #### 一、引言 随着互联网应用的不断发展,单一服务器已经难以满足高并发访问的需求。为了提高系统的可用性和响应速度,负载均衡技术成为了一...

    nginx+tomcat在windows下做负载均衡

    【Nginx+Tomcat在Windows下做负载均衡】 负载均衡是一种网络技术,它通过将流入的网络流量分发到多个服务器,以提高服务的可用性和响应速度,防止单个服务器过载。在这个场景中,Tomcat作为Java应用服务器,由于...

    Nginx+Tomcat6+Membercached 实现负载均衡

    标题中的“Nginx+Tomcat6+Memcached 实现负载均衡”涉及到的是一个常见的Web服务器和应用服务器的架构组合,用于提高系统性能和可扩展性。在这个架构中,Nginx作为反向代理和负载均衡器,Tomcat6是Java应用服务器,...

    Nginx与tomcat 负载均衡

    Nginx与Tomcat的负载均衡是指通过Nginx服务器来实现Tomcat集群的负载均衡,以提高系统的高性能和可扩展性。下面是实现负载均衡的详细步骤和知识点: 一、环境准备 * Nginx 1.8.0 * Apache Tomcat 6.0.33 二、目标...

    Windows+Nginx+Tomcat搭建负载均衡和集群环境同时实现

    本教程将探讨如何在Windows环境下,利用Nginx作为反向代理和负载均衡器,与Tomcat应用服务器配合,搭建一个负载均衡和集群环境。这种配置能够提升系统的稳定性和处理能力,确保即使在服务器压力大的情况下,也能为...

    Nginx+Tomcat+memcached实现集群部署、负载均衡session共享.rar

    在IT行业中,构建高效、可扩展的Web服务是至关重要的,而"Nginx+Tomcat+memcached实现集群部署、负载均衡session共享"是一种常见的解决方案。这个方案结合了Nginx作为反向代理和负载均衡器,Tomcat作为Java应用...

    Windows+Nginx+Tomcat做负载均衡同时实现session共享Demo

    总之,“Windows+Nginx+Tomcat做负载均衡同时实现session共享Demo”是一个实践性强的教学资源,它涵盖了Web服务集群中的关键技术和最佳实践,对于学习和提升系统架构能力非常有帮助。通过深入理解和实践这个Demo,...

    Nginx+Tomcat负载均衡

    最近学习Nginx+tomcat实现 负载均衡。 首先大家注意: 本文章中没有session共享,关于session共享我会在下一篇中讲解,先实现Nginx+tomcat负载均衡再实现session共享。 从网上查了好多资料,多走了很多弯路,现在把...

    tomcat+redis+nginx集群搭建所需jar包

    在Tomcat集群中,Redis可以作为会话复制的解决方案,确保用户会话在各个节点间同步,提高系统的可用性。 3. **Nginx**:Nginx是一款高性能的HTTP和反向代理服务器,以其出色的并发处理能力和低内存占用而著称。在...

    apache-tomcat-7.0.54+memcached+nginx

    总结起来,这个项目涉及到的技术栈包括Tomcat 7集群、memcached集成和Nginx负载均衡。为了实现高效、稳定的Web服务,需要正确配置每个组件,确保会话数据的正确复制、memcached的高效访问以及Nginx的智能负载分配。...

Global site tag (gtag.js) - Google Analytics