apache+tomcat +负载平衡(1)

2、http.conf 同目录下新建mod_jk.conf文件,内容如下(或直接将此内容写到上面的文件中也可)

#加载mod_jk Module

LoadModule jk_module modules/mod_jk-apache-2.0.55.so

#指定 workers.properties文件路径

JkWorkersFile conf/workers.properties

#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器

JkMount /*.jsp controller

也可以根据需要添加,如:

JkMount /servlet/* controller

JkMount /*.do controller

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

3、 在http.conf同目录下新建 workers.properties文件,内容如下

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

#tomcat1

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

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

worker.tomcat1.type=ajp13

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

#tomcat2

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

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

worker.tomcat2.type=ajp13

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

#controller,负载均衡控制器

worker.controller.type=lb

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

worker.controller.sticky_session=1 #此处指定集群是否需要会话复制,如果设为true,则>表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台,Tomcat后,后继的请求会一>直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。

4、修改tomcat配置文件server.xml

修改TOMCAT_HOME/conf/server.xml文件,为了避免冲突,其中一个tomcat就行了,但是要与 workers.properties文件的ip和端口号保持一致 ;

注意:

如果是同一台电脑上安装两个tomcat那么改一个server.xml文件端口号,避免冲突(3外位置需要修改);但我是在虚拟机里安装的就不需要改了。

—改为—

<Connector port=“8080” protocol=“HTTP/1.1”

connectionTimeout=“20000”

redirectPort=“8443” />

改为:

<Connector port=“9080” protocol=“HTTP/1.1”

connectionTimeout=“20000”

redirectPort=“8443” />

改为

5、编写一个测试文件,jsp

建立一个目录test.里面新建一个test.jsp,内容为

<%

System.out.println(new java.util.Date());

%>

把test放到tomcat1,tomcat2的webapps下

6、启动apache,tomcat1,tomcat2,进行测试

观察两个tomcat的控制台的输出:可以看到请求会被tomcat1,tomcat2轮流处理,实现了负载均衡

7、第二部分,配置集群

只配置负载均衡还不行,还要session复制,也就是说其中任何一个tomcat的添加的session,是要同步复制到其它tomcat, 集群内的tomcat都有相同的session

1、修改tomcat1, tomcat2的server.xml,将集群部分配置的在注释符删掉

但是在虚拟机里面,默认的参数可能会导致冲突或异常,所以在一个tomcat里就需要对。cluster进行更详细的配置,见docs/cluster-howto.html

<Cluster className=“org.apache.catalina.ha.tcp.SimpleTcpCluster”

channelSendOptions=“8”>

<Manager className=“org.apache.catalina.ha.session.DeltaManager”

expireSessionsOnShutdown=“false”

notifyListenersOnReplication=“true”/>

<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=“4000”

autoBind=“100”

selectorTimeout=“5000”

maxThreads=“6”/>

<Valve className=“org.apache.catalina.ha.tcp.ReplicationValve”

filter=“”/>

<Deployer className=“org.apache.catalina.ha.deploy.FarmWarDeployer”

tempDir=“/tmp/war-temp/”

deployDir=“/tmp/war-deploy/”

watchDir=“/tmp/war-listen/”

watchEnabled=“false”/>

<Receiver className=“org.apache.catalina.tribes.transport.nio.NioReceiver” port=“4000” …

的4000端口改为4001,以避免与 tomcat冲突,当然,如果是两台电脑,是不用改端口的,去掉注释符即可,虚拟机也看做是两台电脑,不会有冲突。

2、修改测试项目test

修改test.jsp,内容如下

<%@ page contentType=“text/html; charset=GBK” %>

<%@ page import=“java.util.*” %>

Cluster App Test

Server Info:

<%

out.println(request.getLocalAddr() + " : " + request.getLocalPort()+“
”);%>

<%

out.println(“
ID " + session.getId()+”
");

// 如果有新的 Session 属性设置

String dataName = request.getParameter(“dataName”);

if (dataName != null && dataName.length() > 0) {

String dataValue = request.getParameter(“dataValue”);

session.setAttribute(dataName, dataValue);

}

out.print(“Session 列表”);

Enumeration e = session.getAttributeNames();

while (e.hasMoreElements()) {

String name = (String)e.nextElement();

String value = session.getAttribute(name).toString();

out.println( name + " = " + value+“
”);

System.out.println( name + " = " + value);

}

%>

名称:


值:


然后在test 新建WEB-INF目录,WEB-INF下新建web.xml,内容如下

TomcatDemo

注意:在你的应用的web.xml加入   ****即可

test复制到tomcat1,tomcat2的webapps下,重启 apache,tomcat1,tomcat2

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
-RW9Zcqgu-1715498859950)]

[外链图片转存中…(img-gU2jImYo-1715498859951)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 21
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值