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

2023-12-14 16:38

本文主要是介绍Apache+tomcat+mod_jk+centos6.2负载均衡集群配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



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

       我使用两台服务器搭建集群,ip分别为:192.168.40.76 、192.168.40.77 其中76安装的是apache和tomcat作为集群分发,77只安装了tomcat,以下的详细步骤是以76为例编写,因为77只需要安装jdk和 tomcat所以各位只需要参考jdk和tomcat安装方法即可。

1、准备下列程序安装包:(此安装包是本人使用的软件版本,系统版本为centos6.2,此种方法也在centos5.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 -version
java 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

# 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>

 

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

# vim /usr/local/apache/conf/workers.properties
worker.list=wlb , jkstatus    worker.worker1.port=8009   worker.worker1.host=192.168.40.76  worker.worker1.type=ajp13   worker.worker1.lbfactor=1   \#Define preferred failover node for worker1   \#worker.worker1.redirect=worker2    worker.worker2.port=8009   worker.worker2.host=192.168.40.77  worker.worker2.type=ajp13   worker.worker2.lbfactor=1   \# Disable worker2 for all requests except failover   \#worker.worker2.activation=disabled    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   /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、编辑76服务器的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="192.168.40.76"
                          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>
到此处,76服务器的所有配置全都已经完成

11、在77服务器按照上面的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="192.168.40.77"
                          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

用浏览器打开 http://192.168.40.76/examples/servlets/servlet/SessionExample 填写表单提交,然后关闭一台tomcat

Sessions Example    Session ID: 8114091612E32B0EF1F4FAB5DDF1A417.worker1   Created: Fri Aug 31 02:11:15 CST 2012  Last Accessed: Fri Aug 31 02:11:15 CST 2012  The following data is in your session:  laughing = jinxiao  

再次刷新表单,看提交的内容是否还在。(注意红色字体session id 处的变化)

Sessions Example    Session ID: 8114091612E32B0EF1F4FAB5DDF1A417.worker2   Created: Fri Aug 31 02:11:15 CST 2012  Last Accessed: Fri Aug 31 02:26:40 CST 2012  The following data is in your session:  laughing = jinxiao  


Aug 30th, 2012

注意此处的examples项目在worker.properties文件中是有配置的。所以才能正常访问。

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

这篇关于Apache+tomcat+mod_jk+centos6.2负载均衡集群配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/493257

相关文章

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

SpringBoot中配置Redis连接池的完整指南

《SpringBoot中配置Redis连接池的完整指南》这篇文章主要为大家详细介绍了SpringBoot中配置Redis连接池的完整指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以... 目录一、添加依赖二、配置 Redis 连接池三、测试 Redis 操作四、完整示例代码(一)pom.

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

如何在Mac上安装并配置JDK环境变量详细步骤

《如何在Mac上安装并配置JDK环境变量详细步骤》:本文主要介绍如何在Mac上安装并配置JDK环境变量详细步骤,包括下载JDK、安装JDK、配置环境变量、验证JDK配置以及可选地设置PowerSh... 目录步骤 1:下载JDK步骤 2:安装JDK步骤 3:配置环境变量1. 编辑~/.zshrc(对于zsh

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J