Apache+tomcat+mod_jk+centos6.2负载均衡集群配置

转载 2013年12月03日 10:47:20
 本日志是整理的使用jk搭建apache和tomcat负载均衡集群,其中并没有涉及到session的复制,请查看日志的朋友留意。

       我使用两台服务器搭建集群,ip分别为:172.16.18.225、172.16.18 .226 、172.16.18 .227 其中227安装的是apache作为集群分发,225、226只安装了tomcat,以下的详细步骤是以227、225为例编写,227只需要安装apache及mod_jk和配置文件即可,因为225、226只需要安装jdk和 tomcat所以各位只需要参考jdk和tomcat安装方法即可。

1、准备下列程序安装包:(此安装包是本人使用的软件版本,系统版本为centos6.4,其他版本系统尚未测试过)


jdk-6u25-linux-i586.bin (注意:如果你的jdk是jdk-6u25-linux-i586-rpm.bin则需要在安装时作出调整,因为rpm包不能手动指定安装路径,jdk的rpm默认是安装到/usr/local目录下,且环境变量不用手动设置。如果是菜鸟尽量不要使用rpm包
httpd-2.2.19.tar.gz
apache-tomcat-6.0.20.zip
tomcat-connectors-1.2.32-src.tar.gz (mod_jk 也叫 JK,这是一款 Apache/IIS 用来连接后台Tomcat的模块,支持集群和负载均衡。)


2、安装JDK
# cp jdk-6u25-linux-i586.bin /usr/local/java
# cd /usr/local/java
# chmod +x jdk-6u25-linux-i586.bin  (更改执行文件权限)
# ./jdk-6u25-linux-i586-rpm.bin   (开始安装jdk
注:安装完成后悔在/usr/local/java的目录下生产一个JDK的文件夹。此目录就是java的home目录;但是如果你使用的是rpm包,则此java的home目录会自动生成在/urs/java下面

 

3、配置jdk环境变量
# vim /etc/profile

打开profile文件后定位到最后一行在unset i 上面加入以下内容:


  export JAVA_HOME=/usr/java/jdk1.6.0_25
  export PATH=$JAVA_HOME/bin:$PATH:.
  export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

保存退出;


# source /etc/profile   (重置profle文件

检查JDK是否安装成功。

# java -versionjava version "1.6.0_25"

Java(TM) SE Runtime Environment (build 1.6.0_25-b06) Java HotSpot(TM) Server VM (build 20.0-b11, mixed mode)

如果看到以上JVM版本及相关信息,即安装成功!


4、安装Apache

安装apache之前产看自己系统中是否有依赖包  安装yum -y install gcc yum -y install gcc-c++ 

# tar fvxz httpd-2.2.19.tar.gz
# cd httpd-2.2.19/
# ./configure --prefix=/usr/local/apache --enable-so --enable-mods-shared="proxy proxy_http proxy_ftp proxy_connect proxy_balancer headers"    (注:执行完成后,apache会被安装到目录 /usr/local/apache下)
# make
# make install
注:此处一般不会出问题。但是也不排除apache不能安装成功的可能性。我在第一次安装的时候因为系统再带软件太多,所以不能正常安装apache,各位朋友安装完成apache以后可以进入apache的安装目录的bin目录,执行 ./apachectl start  之后查看是否已经启动成功。


5、安装Tomcat
# tar zxvf apache-tomcat-6.0.20.tar.gz
# mv apache-tomcat-6.0.20 /usr/local/tomcat


6、安装tomcat-connectors
# tar zxvf tomcat-connectors-1.2.32-src.tar.gz
# cd tomcat-connectors-1.2.32-src/native/
# ./configure --with-apxs=/usr/local/apache/bin/apxs --with-java-home=/usr/local/java/jdk1.6.0_25/    (注:此处的apache和jdk路径是你jdk的真正安装路径。如果你的jdk不是安装到此路径。请安装实际情况修改) 
# make
# make install

注意:安装完成tomcat-connectors之后,查看apache目录下的modules目录,是否多出一些.so文件。这些文件即jk的配置信息文件

 

7、配置httpd.conf 文件
# vim /usr/local/apache/conf/httpd.conf


在文件最后添加

LoadModule jk_module modules/mod_jk.so

<IfModule jk_module>

JkWorkersFile conf/workers.properties

 JkMountFile conf/uriworkermap.properties

 JkLogFile logs/mod_jk.log

 JkLogLevel warn

 </IfModule>

 此文件中serviceName  www.baidu.com:80 改为

serviceName  localhost:80
还需在上面加上下述命令,来制定apache分配的文件类型:
 
#指定哪些请求交给Tomcat处理,loadbalancer为在workers.properties中配置的分发器名
JkMount /*.do wlb
JkMount /*.jsp wlb
#让Apache支持对servlet传送,用以Tomcat解析 
JkMount /servlet/* wlb
JkMount /*.html wlb
JkMount /* wlb


同样将#  vim /etc/httpd/conf/httpd.conf 
中 
serviceName www.baidu.com:80 改为
serviceName  localhost:80 

8、创建并配置workers.properties文件

# vim /usr/local/apache/conf/workers.properties
worker.list=wlb , jkstatus
worker.worker1.port=8009
worker.worker1.host=172.16.18.225 
worker.worker1.type=ajp13
worker.worker1.lbfactor=1
worker.worker2.port=8009
worker.worker2.host=172.16.18.226
worker.worker2.type=ajp13
worker.worker2.lbfactor=1
worker.wlb.type=lb
worker.wlb.balance_workers=worker1,worker2
worker.jkstatus.type=status注意:workers文件是我们自己创建的,其中worker1和worker2分别代表76和77服务器的tomcat

 

9、创建并配置uriworkermap.properties
# vim /usr/local/apache/conf/uriworkermap.properties

 /admin/*=wlb 

   /manager/*=wlb   

   /jsp-examples/*=wlb  

   /servlets-examples/*=wlb
/cngi/*=wlb 

 /docs/*=wlb  

   /examples/*=wlb 

   /*.jsp=wlb  

   /servlets-examples/*.jpeg=wlb  

   /jkmanager=jkstatus 

   /*.gif=wlb 

   /*.jpg=wlb

   /*.png=wlb

   /*.css=wlb

   /*.js=wlb

   /*.htm=wlb

   /*.html=wlb

注意:其中红色字体表明的cngi即我们的项目名称,各位如果配置自己的集群,需要在这里面加入你们的项目根目录,不然在集群中不能访问你们的项目。其中红色字体的含义是cngi目录下的所有文件均可访问。

前面有叹号的是表示在集群中,不能访问的文件,因为现在网上大多数转载,所以此处基本都一样,各位要注意,如果你照样复制过去,会导致这些css以及图片等文件,不能正常访问。所以大家搭建好集群后如果发现样式消失等问题,可以将里面的那些叹号全都去掉即可

 

10、编辑225服务器的tomcat server.xml文件

# vim /usr/local/tomcat/conf/server.xml

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

修改为:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="worker1">


在Engine标签下添加下面一段代码:注意其中的红色字体,需要修改为你自己的ip
<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="172.16.18.225 "
                          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>
到此处,225服务器的所有配置全都已经完成

11、在226服务器按照上面的jdk和tomcat安装方法,安装之后,修改tomcat的server.xml

# vim /usr/local/tomcat/conf/server.xml

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

修改为:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="worker2">


在Engine标签下添加下面一段代码:注意其中的红色字体,需要修改为你自己的ip
<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="172.16.18.226"
                          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>

所有配置完全完成

启动 tomcat 和 apache

# /usr/local/tomcat/bin/startup.sh
# /usr/local/tomcat/bin/startup.sh
# /usr/local/apache/bin/apachectl start
tomcat  examples/jsp/ 目录下 新建一个index.jsp  225、226的的jsp内容不同。注意这里测试都是调用一个jsp即可,当实际应用时要用虚拟盘nfs进行挂载,来实现tomcat的读取、操作路径一致。

用浏览器打开 http://192.168.40.76/examples/jsp/index.jsp 然后关闭显示jsp的这台tomcat ,刷新 看页面变化

  如果你的浏览器中按照上面的显示,说明集群配置已经成功。其中需要注意的是worker.properties文件的配置。在向集群中部署项目的时候一定要将项目的根目录添加到这个配置文件中。其中部署项目的时候只需要向两个服务器的tomcat中部署即可,apache中不用部署,而访问则访问 apache。


此运行过程主要是apache调用
mod_jk 模块 ,加载tomcat 使用tomcat找到 文件 实现集群







Apache+tomcat+mod_jk+centos6.2负载均衡集群配置--转载

转载地址:http://blog.163.com/chenhui_java/blog/static/17267249420128101191860/ 注: 由于长期受转载毒害,所以本人日志均是原创;...
  • davidwang456
  • davidwang456
  • 2013年09月29日 12:52
  • 365

dubbo服务集群配置及负载均衡策略

dubbo服务集群配置及负载均衡策略 集群容错模式 Dubbo 官方文档:用户指南 >> 示例 >> 集群容错 1、Failover Cluster(默认)      失败自动切换,当出现失败,重...
  • qq_34021712
  • qq_34021712
  • 2017年06月04日 11:58
  • 773

nginx tomcat 集群与负载均衡配置实例

一、nginx tomcat 中用到的概念介绍 1、反向代理,当客户端的请求到来之后,反向代理接收这个请求然后将这个请求转发到后台的服务器上,如果做负载均衡的话,就会将这个请求分发到负载均衡的那些服务...
  • QH_JAVA
  • QH_JAVA
  • 2015年05月17日 20:24
  • 4014

搭建高性能Jboss负载均衡集群

负载均衡集群是由两台或者两台以上的服务器组成。分为前端负载调度和后端服务两个部分。负载调度部分负载把客户端的请求按照不同的策略分配给后端服务节点,而后端节点是真正提供营养程序服务的部分。与双机热备不同...
  • a1314517love
  • a1314517love
  • 2014年05月25日 08:09
  • 6121

Windows下Nginx+tomcat配置集群负载均衡

Nginx 介绍      Nginx (发音同 engine x)是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发...
  • qwlovedzm
  • qwlovedzm
  • 2016年10月09日 23:55
  • 4264

Jenkins分布式集群配置

Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满足各式的集成需求。通过配置jenkins分布式环境,将不同的任务下发到多台机器执行,提高jenkins处...
  • tianwei7518
  • tianwei7518
  • 2017年03月30日 00:23
  • 3601

Red5的集群方式

本来一直想总结下关于Red5服务器的知识。
  • xiangsheng1234
  • xiangsheng1234
  • 2014年11月07日 17:02
  • 1143

Oracle RAC 客户端JDBC集群负载均衡的配置方法

Oracle RAC 客户端JDBC集群负载均衡的配置方法 http://space.itpub.net/23135684/viewspace-630945...
  • orion61
  • orion61
  • 2011年08月29日 22:39
  • 1587

Nginx 集群,负载均衡和配置参数解释

随着现代互联网的飞速推进,集群分布式,负载均衡 等等听上去很高大上的名词不绝于耳。今天就好好说说Nginx不废话,直接上配置文件。 1.Nginx 的目录介绍: ….conf 配置文件 … h...
  • liiuijkiuu
  • liiuijkiuu
  • 2016年10月24日 23:18
  • 707

tomcat5.5+apache2.2负载均衡集群配置

所谓负载均衡(loadbalance)所指的是,在服务器端短时间内获得大量的请求,单一服务器无法在一个较短的时间内响应这些请求, 还有一个作用是容错功能,只要有一台机器存活即可提供服务此时服务器需要一...
  • duling509
  • duling509
  • 2009年01月21日 15:45
  • 1204
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Apache+tomcat+mod_jk+centos6.2负载均衡集群配置
举报原因:
原因补充:

(最多只允许输入30个字)