这几天搞晕了,终于把这个apache+tomcat+负载平衡配置好了,晕啊!感觉有点难
1、负载平衡:
每台服务器都是独立的,只是对请求的负载进行平衡,而不对状态(SESSION)进行复制。状态复制(集群):先进行负载平衡,再在各服务器间复制应用状态。
2、apache负载均衡的原理:
mod_jk负载平衡原理:
使用mod_jk默认的以轮循方式进行平衡负载,假设有四个服务器节点,有10个请求,则
第一个节点会得到1,5,9请求;
第二个节点会得到2,6,10请求;
第三个节点会得到3,7请求;
第四个节点会得到4,8请求;
Mod_JK2负载均衡与故障复原:
Apache httpd是当成web服务器,使用mod_jk2将请求传送给Tomcat,就可以使用mod_jk2的负载均衡与容错功能。带有 mod_jk2的Apache(httpd)可以做的事情包括:
A、将请求分配至一或多个Tomcat实例上你可以在mod_jk2的workers.properties文件中,设定许多Tomcat实例,并赋于每个实例一个lb_factor值,以作为请求分配的加权因子
B、侦测Tomcat实例是否失败当Tomcat实例的连接器服务不再响应时,mod_jk2会及时侦测到,并停止将请求送给它。其他的Tomcat 实例则会接受失效实例的负载。
C、侦测Tomcat实例在失效后的何时恢复因连接器服务失效,而停止将请求分配给Tomcat实例之后,mod_jk2会周期性地检查是否已恢复使用性,并自动将其加入现行的Tomcat实例池中。
实践证明,在各应用服务器之间不需要状态复制的情况下,负载平衡可以达到性能的线性增长及更高的并发需求。
集群原理:
集群方式也是使用这种方法进行平衡。Tomcat中的集群原理是通过组播的方式进行节点的查找并使用TCP连接进行会话的复制
集群与负载均衡的优缺点:
不足:
集群不同于负载平衡的是,由于集群服务需要在处理请求之间不断地进行会话复制,复制后的会话将会慢慢变得庞大,因此它的资:
源占用率是非常高的,如果在并发量大的应用中,复制的会话大小会变得相当大,而使用的总内存更是会迅速升高。
优点:
但集群的会话复制,增加了系统的高可用性。由于在每台服务器都保存有用户的Session信息,如果服务器群中某台当机,应用可以自动切换到其它服务器上继续运行,而用户的信息不会丢失,这提高了应用的冗错性
需要文件:
jakarta-tomcat-connectors-1.2.14-src.tar.gz
httpd-2.2.19.tar.bz2
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.conf2、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
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,则表明需求会话复制。
<Server port="8005" shutdown="SHUTDOWN">—改为—<Server port="9005" shutdown="SHUTDOWN">
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 改为: <Connector port="9080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />改为<Connector port="9009" protocol="AJP/1.3" redirectPort="8443" />5、编写一个测试文件,jsp
<% System.out.println(new java.util.Date()); %>把test放到tomcat1,tomcat2的webapps下
<Engine name="Catalina2" defaultHost="localhost" jvmRoute="jvm3"><!--这里jvmRoute不管tomcat是不是在同一台机器,都不能相同,如果相同就会产生冲突。-->一般情况下直接去掉注释就可以了:
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>但是在虚拟机里面,默认的参数可能会导致冲突或异常,所以在一个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"/> <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="auto" <!--注意这里最好是用ip或者是localhost,如果在虚拟机里这样配置就会出现,虚拟机的ip与物理ip一样,就会产生端口冲突;--> 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>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver" port="4000" ...
的4000端口改为4001,以避免与 tomcat冲突,当然,如果是两台电脑,是不用改端口的,去掉注释符即可,虚拟机也看做是两台电脑,不会有冲突。
<%@ page contentType="text/html; charset=GBK" %> <%@ page import="java.util.*" %> <html><head><title>Cluster App Test</title></head> <body> Server Info: <% out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%> <% out.println("<br> ID " + session.getId()+"<br>"); // 如果有新的 Session 属性设置 String dataName = request.getParameter("dataName"); if (dataName != null && dataName.length() > 0) { String dataValue = request.getParameter("dataValue"); session.setAttribute(dataName, dataValue); } out.print("<b>Session 列表</b>"); Enumeration e = session.getAttributeNames(); while (e.hasMoreElements()) { String name = (String)e.nextElement(); String value = session.getAttribute(name).toString(); out.println( name + " = " + value+"<br>"); System.out.println( name + " = " + value); } %> <form action="index.jsp" method="POST"> 名称:<input type=text size=20 name="dataName"> <br> 值:<input type=text size=20 name="dataValue"> <br> <input type=submit> </form> </body> </html>然后在test 新建WEB-INF目录,WEB-INF下新建web.xml,内容如下
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2eehttp://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4"> <display-name>TomcatDemo</display-name> <distributable/> </web-app>注意:在你的应用的web.xml加入 <distributable/>即可
不断刷新桌面,Server不会变,其它会变;