准备软件 1、 Tomcat5.5.17,下载地址:http://www.apache.org/dist/tomcat/tomcat-5/v5.5.17/bin/2、 Apache2.2.3,下载地址:http://apache.justdn.org/httpd/binaries/win32/apache_2.2.3-win32-x86-no_ssl.msi ;3、 mod_jk-1.2.20-apache-2.2.3.so模块,,下载地址:http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.20/。集群与负载平衡 使用mod_jk默认的以轮循方式进行平衡负载,而集群方式也是使用这种方法进行平衡。Tomcat中的集群原理是通过组播的方式进行节点的查找并使用TCP连接进行会话的复制。
集群不同于负载平衡的是,由于集群服务需要在处理请求之间不断地进行会话复制,复制后的会话将会慢慢变得庞大,因此它的资源占用率是非常高的,如果在并发量大的应用中,复制的会话大小会变得相当大,而使用的总内存更是会迅速升高。
但集群的会话复制,增加了系统的高可用性。由于在每台服务器都保存有用户的Session信息,如果服务器群中某台当机,应用可以自动切换到其它服务器上继续运行,而用户的信息不会丢失,这提高了应用的冗错性。
具体采用负载平衡还是集群,这要看应用的需求了。安装配置Apache
安装前请确认IIS服务停止,因为Apache可能会使用80端口.1 、下载 Apache 的安装程序 apache_2.2.3-win32-x86-no_ssl.exe 后,安装很简单,一路回车,就此略过。
2 、安装完毕后,将下载的 mod_jk-1.2.20-apache-2.2.3.so改名为mod_jk.so并 复制到 Apache 安装目录下的 modules 子目录中。
3 、然后进入 Apache 安装目录下的 conf 子目录中,打开 httpd.conf 配置文件,在最后插入以下一行: Include conf/mod_jk.conf
4、 在 conf 子目录下,建立一个新的配置文件: mod_jk.conf ,此文件为 Apache 加载连接器的配置文件,文件名可修改,但要与 httpd.conf 中 Include 的文件名一致,在logs子目录下建立日志文件mod_jk.log,mod_jk.conf内容如下:
注:以上定义了三个worker,分别为node1,node2,node2;8009端口是Tomcat默认的ajp端口;定义了一个负载平衡服务器loadbalancer,相关的详细说明可以看官方的网站文档:http://tomcat.apache.org/connectors-doc/,其它节点的定义可以直接Copy,修改一下节点名及IP就好了。A、worker.list=loadbalancer
设定工作的负载平衡器,各Tomcat节点不能加入此列表。
B、worker.server99.lbfactor
负载平衡的权重比,如果此权重比越大,则分配到此节点的请求越多,如以上两个节点的权重比为1:1,则为平均分配。
C、worker.loadbalancer.balance_workers=node1,node2,node3
指定此负载平衡器负责的Tomcat应用节点。
D、worker.loadbalancer.sticky_session=true
此处指定集群是否需要会话复制,如果设为true,则表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台Tomcat后,后继的请求会一直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。当设置为0(false)时,是基于请求的负载均衡,为1(true)时是基于用户的负载均衡。
E、worker.loadbalancer.sticky_session_force=true
如果上面的sticky_session设为true时,建议此处也设为true,此参数表明如果集群中某台Tomcat服务器在多次请求没有响应后,是否将当前的请求,转发到其它Tomcat服务器上处理;此参数在sticky_session=true时,影响比较大,会导致转发到其它Tomcat服务器上的请求,找不到原来的session,所以如果此时请求中有读取session中某些信息的话,就会导致应用的null异常。
Powered by: BlogJava Copyright © zolly