apache+tomcat集群环境搭建

apache+tomcat集群环境搭建

1. 什么是集群
        简单理解就是:将项目同时部署在多台服务器上(tomcat)运行,通过一个web服务器(Apache/nginx)进行请求分发和负载均衡,将同时访问的多个请求按照权重通过分发到各个应用服务器上,从而大大减轻了单个服务器的压力,同时也实现了高并发。若某个应用服务器宕机了,也不会导致项目无法进行运行。
        生活场景理解集群:一家饭店生意平平淡淡,最初只请了一个服务员。后面客人多了,一个服务员忙不过来,于是又请了二个服务员。那这三个服务员的关系就集群。
服务端集群:
a.水平集群 :将服务器安装在 各个不同的计算机上 (失败迁移)
b.垂直集群 :将多个服务器,安装在同一个计算机上 (负载均衡)
2. 搭建集群
这里搭建集群的环境是windows10系统、Apache2.4.43、Tomcat7.0.92
将Apache(一个)和Tomcat(多个)放置同个目录,方便配置。
Apache用来接收请求并分发给tomcat,以下示例为二个tomcat

  • 工具准备
    解压后直接使用
    Apache下载
    tomcat下载
  • 修改配置
    修改Apache中conf/httpd.conf文件
    Define SRVROOT 修改为Apache解压后的根路劲(G:/cluster/Apache24)
  • 注册服务
    将Apache配置环境变量Path中:配置Apache的bin路劲下(G:\cluster\Apache24\bin)
    用管理员身份运行cmd
    加入windows服务:httpd -k install
    如果安装后显示Errorsreported here must be corrected before the service can be started.表示安装成功,如果该句后面有错误信息,表示服务安装失败。输入service可以查看服务中多了一个Apache2.4
    启动服务: net start Apache2.4
    删除服务: sc delete 服务名
    停止服务: httpd –k stop
    启动服务后,访问http://localhost/,网页可以正常打开即可
  • 修改tomcat配置
    修改各个tomcat中conf/server.xml文件
    • 修改端口号:Server端口、http端口、ajp端口,保证多个tomcat端口不冲突
    • 放开注释:
      <Cluster className=“org.apache.catalina.ha.tcp.SimpleTcpCluster”/>
    • 配置Tomcat引擎:jvmRoute=“服务名”
<Server port="1005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JasperListener" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>
  <Service name="Catalina">
    <Connector port="1080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <Connector port="1009" protocol="AJP/1.3" redirectPort="8443" />
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat-a">
      <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />

      </Host>
    </Engine>
  </Service>
</Server>
  • 配置mod_jk.so
    mod_jk.so下载该链接中的httpd.zip
    下载后放入/Apache24/modules/mod_jk.so
  • 配置workers.poperties文件
    在Apache24的conf/下创建workers.poperties文件,并配置该文件
worker.list=controller,tomcata,tomcatb,tomcatc
#tomcata配置
worker.tomcata.port=1009
worker.tomcata.host=localhost
worker.tomcata.type=ajp13
#负载均衡的权重
worker.tomcata.lbfactor=1

#tomcatb配置
worker.tomcatb.port=2009
worker.tomcatb.host=localhost
worker.tomcatb.type=ajp13
#负载均衡的权重
worker.tomcatb.lbfactor=2

#controller配置
worker.controller.type=lb
worker.controller.balanced_workers=tomcata,tomcatb
worker.controller.sticky_session=false

参数说明:

属性简介
worker.list定义worker对象列表,每个worder对象都应该在后文中分别配置。例如,如果定义了worker.list=A,B,那么就需要配置worker.A.xx=xx worker.B.xx=xx
type协议类型,本书使用的mod_jk1.2.4共支持以下4个类型:ajp12、ajp13、jni、lb。其中,lb表示一个负载平衡worker,可用于设置参与负载平衡的Tomcat服务器,例如:worker.controller.type=lbworker.controller.balanced_workers=Tomcat1,Tomcat2表示集群中的负载均衡是由Tomcat1和Tomcat2协同实现。
port服务器协议的端口号,此配置需要和type属性结合使用。例如,如果type=ajp13,此port的值就是Tomcat服务器中ajp13协议的端口号。
host服务器的IP地址。
lbfactor服务器权重。某一服务器的权重越大,分配到该服务器的请求就越多。例如,如果配置的是worker.Tomcat1.lbfactor=1,worker.Tomcat2.lbfactor=2,那么集群在处理请求时,会按照“Tomat1处理请求–Tomcat2处理请求-- Tomcat2处理请求”的顺序,循环执行。
sticky_session会话保持,一般设置为false。如果设置为true,则表示同一用户的同一session 始终和一个 Tomcat 节点交互,即多个Tomcat之间无法共享session。
  • 配置mod_jk.conf文件
    在Apache24的conf/下创建mod_jk.conf文件,并配置该文件
#加载mod_jk_so
loadModule jk_module	modules/mod_jk.so
#加载workers.properties
JKWorkersFile conf/workers.properties
#需要拦截的内容  /* 表示所有请求
JkMount /* controller
  • 配置httpd.conf文件
    打开Apache24的conf/httpd.conf将mod_jk.conf引进去,在httpd.conf最下面通过下面语句引入
#加载mod_jk.conf文件,该文件在启动apache时自动加载
Include conf/mod_jk.conf

3.测试
测试失败迁移 负载均衡 session共享
创建web项目,在项目的web.xml中添加<distributable/>编辑index.jsp
将该web项目分别放入每个tomcat/webapps下
分别启动Apache、tomcata、tomcatb

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>tomcata</title>
  </head>
  <body>
		sessionID:
		<%
				out.print(session.getId());		
		%>
  </body>
</html>

负载均衡 session共享测试结果如下即完成:

sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-a	// 第一次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-b	// 第二次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-b	// 第三次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-a	// 第四次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-b	// 第五次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-b	// 第六次

接着关闭一个tomcatb服务,测试失败迁移,显示结果如下即完成:

sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-a	// 第一次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-a	// 第二次
sessionID: 3D99E071146FAC17F266DAAFFA46009F.tomcat-a	// 第三次

4.问题整理
a.安装时报错:
问题:Could not reliably determine the server’s fully qualified domain name, using xxxx:xxxx:xxxx:ffff:68e3:fdd1.
Set the ‘ServerName’ directive globally to suppress this message
解决:在httpd.conf文件加上这句ServerName localhost:80,再重新执行命令httpd.exe -k install -n apache
b.执行安装时若存在端口号被占用可修改:Listen 80 (80修改为新的端口)
查看端口号:netstat –ano
c.apache启动报错,按照以下顺序依次排查:
httpd.conf->mod_jk.conf->mod_jk.so,workers.properties

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值