C、侦测Tomcat实例在失效后的何时恢复因连接器服务失效,而停止将请求分配给Tomcat实例之后,mod_jk2会周期性地检查是否已恢复使用性,并自动将其加入现行的Tomcat实例池中。
实践证明,在各应用服务器之间不需要状态复制的情况下,负载平衡可以达到性能的线性增长及更高的并发需求。
集群原理:
集群方式也是使用这种方法进行平衡。Tomcat中的集群原理是通过组播的方式进行节点的查找并使用TCP连接进行会话的复制
集群与负载均衡的优缺点:
不足:
集群不同于负载平衡的是,由于集群服务需要在处理请求之间不断地进行会话复制,复制后的会话将会慢慢变得庞大,因此它的资:
源占用率是非常高的,如果在并发量大的应用中,复制的会话大小会变得相当大,而使用的总内存更是会迅速升高。
优点:
但集群的会话复制,增加了系统的高可用性。由于在每台服务器都保存有用户的Session信息,如果服务器群中某台当机,应用可以自动切换到其它服务器上继续运行,而用户的信息不会丢失,这提高了应用的冗错性
需要文件:
jakarta-tomcat-connectors-1.2.14-src.tar.gz
apache-tomcat-7.0.19.tar(windows和linux下的都需要)
我是在win7下进行配置的,安装 Vmware7.1+RedHat6.1。
win7下,安装tomcat7
在RedHat下面安装tomcat7+apache2.2
在RedHat安装jakarta-tomcat-connectors-1.2.14-src.tar.gz
1、修改httpd.cnf
在apache安装目录下conf目录中找到httpd.conf,在文件最后加上下面两句话就可以了
LoadModule jk_module modules/mod_jk.so
include /apache2.2/conf/mod_jk.conf
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/”
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

学习分享
在当下这个信息共享的时代,很多资源都可以在网络上找到,只取决于你愿不愿意找或是找的方法对不对了
很多朋友不是没有资料,大多都是有几十上百个G,但是杂乱无章,不知道怎么看从哪看起,甚至是看后就忘
如果大家觉得自己在网上找的资料非常杂乱、不成体系的话,我也分享一套给大家,比较系统,我平常自己也会经常研读。
2021最新上万页的大厂面试真题
七大模块学习资料:如NDK模块开发、Android框架体系架构…
2021大厂面试真题:
只有系统,有方向的学习,才能在短时间内迅速提高自己的技术,只有不断地学习,不懈的努力才能拥有更好的技术,才能在互联网行业中立于不败之地。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
题**
[外链图片转存中…(img-kYJv0qxG-1712250308817)]
七大模块学习资料:如NDK模块开发、Android框架体系架构…
[外链图片转存中…(img-4bihc5UG-1712250308817)]
2021大厂面试真题:
[外链图片转存中…(img-ZxJqYsiv-1712250308818)]
只有系统,有方向的学习,才能在短时间内迅速提高自己的技术,只有不断地学习,不懈的努力才能拥有更好的技术,才能在互联网行业中立于不败之地。