`
cloudtech
  • 浏览: 4604614 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
文章分类
社区版块
存档分类
最新评论

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

 
阅读更多

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

Tomcat6 集群配置端口规划:

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

序号

SHUTDOWN

AJP

http

集群Receiver

1

8005

8009

8080

5001

2

8015

8019

8081

5002

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://tomcat6tomcat6名称与上面的配置一样。

Apache + Tomcat 负载均衡配置:

Apache Http ServerTomcat连接有三种方式,可以参考:

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

本文只介绍最常用的JK方式,需要2个文件:

1httpd.conf

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

2workers.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.x2.2.x,以及不同的平台。一般对于AIXHP-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 端口号,在tomcatserver.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 端口号,在tomcatserver.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 端口号,在tomcatserver.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 端口号,在tomcatserver.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,则表明为会话粘性,不进行会话复制

测试:

命令:ab -n 50000 -c 1000 http://127.0.0.1/index.jsp

根据具体情况增加或减少-n -c 参数大小

本文链接:http://blog.csdn.net/myloon/archive/2009/11/05/4774320.aspx

分享到:
评论

相关推荐

    tomcat8+Redis+nginx

    tomcat8+Redis+nginx负载均衡集群部署,apache-tomcat-8.0.47+nginx-1.13.6+Redis-x64-3.2.100

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

    配置apache+tomcat负载均衡和session复制,并且解决了tomcat报2009-6-5 10:10:12 org.apache.jk.common.ChannelSocket processConnection 警告: processCallbacks status 2 的问题

    Nginx+Tomcat负载均衡

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

    tomcat+linux负载均衡集群配置

    tomcat+apache+linux负载均衡集群配置反向代理

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

    非常经典nginx-1.11.3+apache-tomcat-7.0.47搭建高性能负载均衡集群适合初学者、入门手册。

    性能调优 海量并发 系统架构

    Nginx+tomcat集群Memcached+Session复制 高性能高并发服务器架构 基于nginx的tomcat负载均衡和集群 实现多服务器负载均衡 系统性能优化 数据库 Nginx+Squid负载均衡 配置好的集群 总共三十个文档"&gt;Apache+Tomcat+...

    Nginx+Tomcat搭建高性能负载均衡集群的实现方法

    一、 目标实现高性能负载均衡的Tomcat集群: 二、步骤 1、首先下载Nginx,要下载稳定版: 2、然后解压两个Tomcat,分别命名为apache-tomcat-6.0.33-1和apache-tomcat-6.0.33-2: 3、然后修改这两个Tomcat的...

    Nginx+Tomcat高性能负载均衡集群搭建教程

    Nginx是一个高性能的HTTP服务器/反向代理服务器及电子邮件(IMAP/POP3...在这里我们采用集群部署方式,使用多个Tomcat,反向代理使用Nginx。 架构如下: 准备工作 apache-tomcat-7.0.61 nginx-1.12.2 Redis-x64-3.2.10

    NGINX和tomcat配置

    Nginx+tomcat配置集群负载均衡,了解了二者之间的区别于应用场景,对于搭建服务帮助很大。nginx配置简单,不想apache配置那么复杂

    tomcat6_apache2.2_ajp 负载均衡加集群实战分享

    环境: ——————————————– 一台apache2.2服务器,三台tomcat服务器: apache2.2服务器 1.ip:192.168.1.20 2.只装apache软件:...3.测试应用程序test文件夹放在tomcat6的webapps目录下 操作系统均为:cen

    Nginx与Tomcat实现动静态分离和负载均衡

    本文介绍了Nginx与Tomcat实现动静态分离和负载均衡,所谓动静分离就是通过nginx(或apache等)来处理用户端请求的图片、html等静态的文件,tomcat(或weblogic)处理jsp、do等动态文件,从而达到动静页面访问时通过...

    Apache2.2以上版本与Tomcat整合配置及负载均衡实现

    下面是实现2个tomcat实现负载均衡,如果只有一个则可删除一个 apache2.2以上版本,无需使用jk_mod来集成tomcat,直接使用ajp,很方便。 修改apache配置文件httpd.conf 启用mod_proxy_ajp 代码如下: #LoadModule ...

    用apache和tomcat搭建集群(负载均衡)

    一、集群和负载均衡的概念 (一)集群的概念  集群(Cluster)是由两台或多台节点机(服务器)构成的一种松散耦合的计算节点集合,为用户提供网络服务或应用程序(包括数据库、Web服务和文件服务等)的单一客户视图,...

    nginx+tomcat实现Windows系统下的负载均衡搭建教程

    刚入行没多久就听过‘负载均衡’的大名,到现在因为工作接触的少,所以没什么太多的认识。但自己又对其非常的好奇,所以前两天通过查资料,在自己的笔记本上就搭建了一个超简单的案例(工作中没有时间,晚上到家了...

    Ubuntu10和VirtualBox4实用总结-常用Java Web应用软件 (LNMJ,LAMJ)安装

    本文主要总结了在Ubuntu10下常用Java Web应用软件的安装,特别是LNMJ Web(Linux+Nginx+Mysql+Java Tomcat)架构和LAMJ Web(Linux+Apache+Mysql+Java Tomcat)架构下的软件安装。为进一步配置和实现LNMJ和LAMJ架构(负载...

    Red Hat Linux,Apache2.0+Weblogic9.2负载均衡集群安装配置

    ************************************************************************************************************************ JDK安装步骤 1. 以root身份登录系统 ... 3. 通过chmod +x jdk-1_5_x-rc-linux-i586-...

    Linux+系统运维之系统架构

    本文通过生产应用实例,从运维工程师的角度对目前流行的Web 架构做了实验性的讲解,该系列的文档属于手册类型,可以直接在生产环境...如LAMP、LNMP、LVS Keepalived、Apache+Tomcat 负载均衡和Nginx+Tomcat负载均衡等。

    apache负载均衡的安装和实现方法

    也可以分散到多个tomcat里,如果一台服务器装多个tomcat,那么即使是负载均衡,性能也提高不了太多,不过可以提高稳定性,即容错性。当其中一个主tomcat当掉,其他的tomcat也可以补上,因为tomcat之间实现了Session共享。待...

Global site tag (gtag.js) - Google Analytics