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.*” %>
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
最后
针对于上面的问题,我总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
后
针对于上面的问题,我总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
[外链图片转存中…(img-8LxruZnP-1714792230948)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!