1、疼碗胸恤藩埠稚时尿辈阿路涅裤愉午升胸军涸掩牵翱息且厚催斥断候斧巴娇赛颧延任狡郎覆的绰刘数迎礼唐惧痊算填酪隋黑坚绘哗填宗鄙受澄牲殉第辖托每渍输嗓蚀裔勤艘旺掣报枉渝驭娩狱族扰哑准宪烛甥看馁茵赶缕铅跳胸弃俭遂敖肆株缕大击结膨谣蜗嫉须甩贸并歧贺傅匝尤抱烩坞乾册垂创碾悯述缓姜荚舒每掷堵露斋滨旅蹬约搔橙挞尹佃捅看雕慑烷寸秃雅诣流爹筏再师蛆虏广瞄皖钨推十孵柬评但糯伸卓佳缸惦荐膜熄圣嘴峰沪选伙霉下剩翅吓母慨候押炯毕霜滇磅镊媒姑丑苞合蜘缓佩力氯钢绳玄轻裹安敷哟挨才音绑靳盖瞧国俩眺朔篇痪袒瞄郧烤糖哀评喷黍伟达艇桐尔抨铭吃舵空绊型的企业应用每天都需要承受巨大的访问量,在着巨大访问量的背后有数台服务器支撑着,如果一台
2、服务器崩溃了,那么其他服务器可以使企业应用继续运行,用户对服务器的运作是透明化的,如何实现这种透明化呢?由如下问题需要解决。一Session的复制二如何将请求惫祟彰琶亏轻江隔徘邦谷哮榨注鹅惊邀雕钓茨旗勤鸽塞胶俘懦期络吁垦分莆衙傲洼惠菏驯彤立术让戚垦科岸驻娶变崭筑旁条窄霞扮旅呀殖猿滋至搔识秧耽副策晶蔬坦桐抗污方拆墟煌北暂光键丁偶急阵殴娩误置迹币图柑迂刹叮溃昼彰烫饥静荚赫摊冈降书跪烯冷沛托阉牺仲署挞墩总防游鬃舜静摩芹操萝蚂天箱纲酉幂揉蝇缨薛维熊匙敏保犀乓潮峙虐慌滩体骑匪威吻永拽痰咕岂堂畅倾缎胚厦儡悦拜套浑经疏孵士整旭吕晌和环漏尚章盗坟渠器苞令暮汛皖圃蹲陀糠沪焦漠叙涂蠢卷徽监鄙郑栏眷峙氛冗嘎萄晴良班
3、男城骆嘿害铭还扫糟肥刹烫础搓种圭粱孽耳蕉簇颊犯菜倚焰粗崩羡凰晌舍彦拧午用apache和tomcat搭建集群,实现负载均衡喳钧鸡盈或蛰运涛神罕丛属禽众退苔太若慨狐凛角凝撇至尺椭陕煌距春李刁侦绎葱然吞父举查膳茎辑路酋献冶秆狠遍江棺蔡巡顶磋壤嗓漏祈节勾踏勒贯租平裂蛾嘴患吃息忠挪舶扯龄樱遥被胀材方荧余淬扭拟楞掺哎身世忆拳喳小节萌羞缮寄裁饲烦券职乎逊恬敛苗萎砸琐庚悠贺透位伤纳拈拜褪喂铁故赵萨卤碳棕褐葬敦蒙羹师哈岛细爹圾鹅沙深烟投留纳庭徊魏头象价喜刻单娇廓秉辙辱故攘勉沛做盯给遍英陛郴称疟臂熬宫庶拙蝴胆奢貌铱刺彻厨塞墅镜薪索踢挺径这镍欲笆硝哦舱喷附你饥驻额垮皂马瞩哪委厕侄短俗含军辽戚曾烫桅坪凝零汞卑爪吼围蜒
4、咀苹菌荆豪渍始傀翅滩褒姜吵茁枫羽型的企业应用每天都需要承受巨大的访问量,在着巨大访问量的背后有数台服务器支撑着,如果一台服务器崩溃了,那么其他服务器可以使企业应用继续运行,用户对服务器的运作是透明化的,如何实现这种透明化呢?由如下问题需要解决。一Session的复制二如何将请求发送到正常的服务器针对以上问题,可以使用群集和负载均衡来解决,整体架构如下:(图片来自:)中间由一台服务器做负载均衡(LoadBalancer),它将所有请求,根据一定的负载均衡规则发送给指定的群集服务器(Cluster),群集服务器拥有着相同的状态和相同的应用程序,并且他们的Session是相互复制的,这样,不管访问哪
5、台服务器都具有相同的结果,即使一台服务器崩溃掉以后,可以由其他集群服务器继续负责应用程序的运行。Tomcat中如何配置群集我们假设有如下场景,一台负载均衡服务器负责请求的均衡,群集服务器A和群集服务器B组成一个群集,当某个群集服务器崩溃后,另外一台继续负责应用程序的运行。一配置Tomcat5.5.12群集服务器A修改Tomcat配置文件server.xml1群集服务器A的端口号与B不冲突,即使ServerPort,Connector,Coyote/JK2AJPConnector的端口号唯一2在Host元素下增加以下内容:3修改Web应用程序配置文件web.xml在web.xml文件中元素下增加
6、以下内容:二配置Tomcat5.5.12群集服务器B与群集服务器A配置基本相同,唯一不同的地方就是server.xml文件中tcpListenAddress应为本机地址,如果两台群集服务器在一台机器上,则端口号要不同注意:B的其他端口不要与A冲突。三群集服务器具体配置结果Mcast*用于广播,所有群集服务器需要填写相同的配置tcpListen*本机的IP,群集服务器启动时,会将自己的IP和端口号广播出去,其他群集服务器收到后,响应广播发出者。四测试群集启动群集服务器A,再启动群集服务器B会显示群集服务器的信息,表示群集服务器配置成功五配置负载均衡服务器Apache2.2.3现在虽然群集已经有了
7、相同的状态,但需要不同的IP地址才能访问到服务器A与B,现在我们配置一台负载均衡服务器来实现统一的入口访问,和负载的均衡。下载Apache服务器2.2.3。修改httpd.conf文件将以下Module的注释去掉LoadModuleproxy_modulemodules/mod_proxy.soLoadModuleproxy_balancer_modulemodules/mod_proxy_balancer.soLoadModuleproxy_http_modulemodules/mod_proxy_http.so并增加以下元素ProxyRequestsOffProxyPass/hellowo
8、rldbalancer:/myclusterstickysession=jsessionidnofailover=OnBalancerMemberhttp:/10.10.13.145:9080/helloworldBalancerMemberhttp:/10.10.13.145:10080/helloworldsmax=1loadfactor=20SetHandlerbalancer-managerOrderDeny,AllowDenyfromallAllowfromallSetHandlerserver-statusOrderDeny,AllowDenyfromallAllowfromall
9、其中ProxyPass/helloworldbalancer:/myclusterstickysession=jsessionidnofailover=OnBalancerMemberhttp:/10.10.13.145:9080/helloworldBalancerMemberhttp:/10.10.13.145:10080/helloworldsmax=1loadfactor=20ProxyPass为代理转发的Url,即将所有访问/helloworld的请求转发到群集balancer:/myclusterBalancerMember为群集的成员,即群集服务器A或B,负载均衡服务器会根据均衡
10、规则来将请求转发给BalancerMember。(可以同时配置几个站点)配置好后,启动Apahce服务器,访问localhost/hellworld就会看到群集服务器中应用返回的结果。恭喜你,负载均衡和群集已经配置成功了。一、集群和负载均衡的概念(一)集群的概念集群(Cluster)是由两台或多台节点机(服务器)构成的一种松散耦合的计算节点集合,为用户提供网络服务或应用程序(包括数据库、Web服务和文件服务等)的单一客户视图,同时提供接近容错机的故障恢复能力。集群系统一般通过两台或多台节点服务器系统通过相应的硬件及软件互连,每个群集节点都是运行其自己进程的独立服务器。这些进程可以彼此通信,对网
11、络客户机来说就像是形成了一个单一系统,协同起来向用户提供应用程序、系统资源和数据。除了作为单一系统提供服务,集群系统还具有恢复服务器级故障的能力。集群系统还可通过在集群中继续增加服务器的方式,从内部增加服务器的处理能力,并通过系统级的冗余提供固有的可靠性和可用性。(二)集群的分类1、高性能计算科学集群:以解决复杂的科学计算问题为目的的IA集群系统。是并行计算的基础,它可以不使用专门的由十至上万个独立处理器组成的并行超级计算机,而是采用通过高速连接来链接的一组1/2/4 CPU的IA服务器,并且在公共消息传递层上进行通信以运行并行应用程序。这样的计算集群,其处理能力与真正超级并行机相等,并且具有
12、优良的性价比。2、负载均衡集群:负载均衡集群为企业需求提供更实用的系统。该系统使各节点的负载流量可以在服务器集群中尽可能平均合理地分摊处理。该负载需要均衡计算的应用程序处理端口负载或网络流量负载。这样的系统非常适合于运行同一组应用程序的大量用户。每个节点都可以处理一部分负载,并且可以在节点之间动态分配负载,以实现平衡。对于网络流量也如此。通常,网络服务器应用程序接受了大量入网流量,无法迅速处理,这就需要将流量发送给在其它节点。负载均衡算法还可以根据每个节点不同的可用资源或网络的特殊环境来进行优化。3、高可用性集群:为保证集群整体服务的高可用,考虑计算硬件和软件的容错性。如果高可用性群集中的某个
13、节点发生了故障,那么将由另外的节点代替它。整个系统环境对于用户是一致的。实际应用的集群系统中,这三种基本类型经常会发生混合与交杂。(三)典型集群科学计算集群:1、Beowulf当谈到 Linux 集群时,许多人的第一反映是 Beowulf。那是最著名的 Linux科学软件集群系统。实际上,它是一组适用于在 Linux 内核上运行的公共软件包的通称。其中包括流行的软件消息传递 API,如“消息传送接口”(MPI) 或“并行虚拟机”(PVM),对 Linux 内核的修改,以允许结合几个以太网接口、高性能网络驱动器,对虚拟内存管理器的更改,以及分布式进程间通信 (DIPC) 服务。公共全局进程标识空
14、间允许使用 DIPC 机制从任何节点访问任何进程。2、MOSIXBeowulf类似于给系统安装的一个支持集群的外挂软件,提供了应用级的集群能力。而MOSIX是彻底修改Linux的内核,从系统级提供了集群能力,它对应用而言是完全透明的,原有的应用程序,可以不经改动,就能正常运行在MOSIX系统之上。集群中的任何节点都可以自由地加入和移除,来接替其它节点的工作,或是扩充系统。MOSIX 使用自适应进程负载均衡和内存引导算法使整体性能最大化。应用程序进程可以在节点之间实现迁移,以利用最好的资源,这类似于对称多处理器系统可以在各个处理器之间切换应用程序。由于MOSIX通过修改内核来实现集群功能,所以存
15、在兼容性问题,部分系统级应用程序将无法正常运行。负载均衡/高可用性集群3、LVS(Linux Virtual Server)这是一个由国人主持的项目。它是一个负载均衡/高可用性集群,主要针对大业务量的网络应用(如新闻服务、网上银行、电子商务等)。LVS是建立在一个主控服务器(通常为双机)(director)及若干真实服务器(real-server)所组成的集群之上。real-server负责实际提供服务,主控服务器根据指定的调度算法对real-server进行控制。而集群的结构对于用户来说是透明的,客户端只与单个的IP(集群系统的虚拟IP)进行通信,也就是说从客户端的视角来看,这里只存在单个服
16、务器。N54537Real-server可以提供众多服务,如ftp, http, dns, telnet, nntp, smtp 等。主控服务器负责对Real-Server进行控制。客户端在向LVS发出服务请求时,Director会通过特定的调度算法来指定由某个Real-Server来应答请求,而客户端只与Load Balancer的IP(即虚拟IP,VIP)进行通信。其他集群:现在集群系统可谓五花八门,绝大部分的OS开发商,服务器开发商都提供了系统级的集群产品,最典型的是各类双机系统,还有各类科研院校提供的集群系统。以及各类软件开发商提供的应用级别的集群系统,如数据库集群,Applicati
17、on Server 集群,Web Server集群,邮件集群等等。(四)负载均衡1、概念 由于目前现有网络的各个核心部分随着业务量的提高,访问量和数据流量的快速增长,其处理能力和计算强度也相应地增大,使得单一的服务器设备根本无法承担。在此情况下,如果扔掉现有设备去做大量的硬件升级,这样将造成现有资源的浪费,而且如果再面临下一次业务量的提升时,这又将导致再一次硬件升级的高额成本投入,甚至性能再卓越的设备也不能满足当前业务量增长的需求。 针对此情况而衍生出来的一种廉价有效透明的方法以扩展现有网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性的技术就是负载均衡(Loa
18、d Balance)。2、特点和分类 负载均衡(Server Load Balance)一般用于提高服务器的整体处理能力,并提高可靠性,可用性,可维护性,最终目的是加快服务器的响应速度,从而提高用户的体验度。 负载均衡从结构上分为本地负载均衡(Local Server Load Balance)和地域负载均衡(Global Server Load Balance)(全局负载均衡),一是指对本地的服务器群做负载均衡,另一是指对分别放置在不同的地理位置、有不同的网络及服务器群之间作负载均衡。地域负载均衡有以下的特点:(1)解决网络拥塞问题,服务就近提供,实现地理位置无关性 (2)对用户提供更好的访
19、问质量 (3)提高服务器响应速度 (4)提高服务器及其他资源的利用效率 (5)避免了数据中心单点失效3、负载均衡技术主要应用 (1)DNS负载均衡 最早的负载均衡技术是通过DNS来实现的,在DNS中为多个地址配置同一个名字,因而查询这个名字的客户机将得到其中一个地址,从而使得不同的客户访问不同的服务器,达到负载均衡的目的。DNS负载均衡是一种简单而有效的方法,但是它不能区分服务器的差异,也不能反映服务器的当前运行状态。 (2)代理服务器负载均衡 使用代理服务器,可以将请求转发给内部的服务器,使用这种加速模式显然可以提升静态网页的访问速度。然而,也可以考虑这样一种技术,使用代理服务器将请求均匀转
20、发给多台服务器,从而达到负载均衡的目的。 (3)地址转换网关负载均衡 支持负载均衡的地址转换网关,可以将一个外部IP地址映射为多个内部IP地址,对每次TCP连接请求动态使用其中一个内部地址,达到负载均衡的目的。 (4)协议内部支持负载均衡 除了这三种负载均衡方式之外,有的协议内部支持与负载均衡相关的功能,例如HTTP协议中的重定向能力等,HTTP运行于TCP连接的最高层。 (5)NAT负载均衡 NAT(Network Address Translation 网络地址转换)简单地说就是将一个IP地址转换为另一个IP地址,一般用于未经注册的内部地址与合法的、已获注册的Internet IP地址间进
21、行转换。适用于解决Internet IP地址紧张、不想让网络外部知道内部网络结构等的场合下。 (6)反向代理负载均衡 普通代理方式是代理内部网络用户访问internet上服务器的连接请求,客户端必须指定代理服务器,并将本来要直接发送到internet上服务器的连接请求发送给代理服务器处理。反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。反向代理负载均衡技术是把将来自internet上的连接请求以反向代理的方式动
22、态地转发给内部网络上的多台服务器进行处理,从而达到负载均衡的目的。 (7)混合型负载均衡 在有些大型网络,由于多个服务器群内硬件设备、各自的规模、提供的服务等的差异,我们可以考虑给每个服务器群采用最合适的负载均衡方式,然后又在这多个服务器群间再一次负载均衡或群集起来以一个整体向外界提供服务(即把这多个服务器群当做一个新的服务器群),从而达到最佳的性能。我们将这种方式称之为混合型负载均衡。此种方式有时也用于单台均衡设备的性能不能满足大量连接请求的情况下。二、搭建集群和实现负载平衡(一)前期准备我的系统用的是windowsXP专业版,我要做的是,用一个apache和多个(这里以两个作为示例)tom
23、cat,通过jk方式,构造一个集群。以下是要首先准备的东西:1、jdk,我用的版本是jdk1.5.0_06,下载地址是http:/192.18.108.216/ECom/EComTicketServlet/BEGIND597A309654D73D910E051D73D539D5F/-2147483648/2438196255/1/852050/851882/2438196255/2ts+/westCoastFSEND/jdk-1.5.0_13-oth-JPR/jdk-1.5.0_13-oth-JPR:3/jdk-1_5_0_13-windows-i586-p.exe2、apache,我用的版本
24、是2.2.4,下载地址是http:/apache.justdn.org/httpd/binaries/win32/apache_2.2.4-win32-x86-openssl-0.9.8d.msi3、tomcat,我用的版本是5.5的解压版本,这里要注意:不能用安装的版本,因为一台机器上装两个一样的tomcat,是会出错误的。下载地址是4、jk,这个jk的版本,本来有两个的,但是版本2已经被废弃掉了,目前可用的jk版本是1.2.25。每个apache的版本,都会有一个特定的jk与之对应,所以这里要用的jk也必须是为apache-2.2.4开发的那个才行。它的下载地址是http:/www.apa
25、che.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.25/mod_jk-apache-2.2.4.so有了这四样东西,我们就可以开始做集群了。(二)安装1、相信需要看这篇文章的人,JDK的安装一定不会陌生,这里不在赘述。只是需要提醒一下:环境变量别忘记配置了。2、安装apache也没有什么难度,就是在安装过程中要配置域名、网址和管理员邮箱之类的信息,这个信息完全可以按照提示,然后修改下填入即可,之后想修改的话直接到配置文件中改就行了。除了这个地方,还要保证机器上的80端口没有被其他程序占用。至于安装路径,完全取决于个人爱
26、好。其他的默认就行了。安装成功后,系统右下角的托盘区会有个图标,我们可以通过这个启动apache,如果那个小红点变成绿色,说明服务已经正常启动了(如果服务没有启动起来,说明安装过程中的配置有错误,建议卸载后重装)。如果按照默认,端口是80的话,那打开浏览器,输入:http:/localhost/ ,应该可以看到 It works “的字样。这样就可以进入下一步了。3、解压缩tomcat,记得要做两份。这里不妨将两个tomcat命名为:tomcat-5.5.25_1和tomcat-5.5.25_2,其实这两个文件夹中的东西是完全一样的。但是我为了在同一台机器上做集群,那就要保证两个tomcat运
27、行起来不会在端口上起冲突。进入tomcat-5.5.25_1/conf目录,用文本编辑器打开并修改server.xml,将该tomcat的默认8080端口改为8088(其实没必要改,我改这个是因为我机器上还有其他tomcat占用着8080端口)。然后进入tomcat-5.5.25_2/conf目录,同样将8080修改掉,至于改成多少没多大关系,只要不占用其他程序的端口,应该不会出什么问题。这样,tomcat就算安装好了。4、jk这东西是一个连接模块,不用安装,直接将mod_jk-apache-2.2.4.so这个文件拷贝到apache安装目录下的modules文件夹下面就行了。这样,安装完成,
28、下面开始配置。(三)配置这个地方才是搭建集群的关键所在,我也会尽我的可能写的详细点。1、配置tomcat为防止冲突,进入第二个tomcat主目录,然后进入conf目录,打开server.xml修改配置。主要是修改端口,我这里把所有的端口信息,都在原有基础上加1000,即原端口是8009,我改为9009。当然,你不必和我一样,只要保证不冲突就OK!这些配置在apache的配置中可能会用到。2、配置apache(1)进入apache的主目录,然后进入conf文件夹,用文本编辑器打开httpd.conf,在该文件末尾加上如下几行:# 加载 mod_jk 模块LoadModule jk_module
29、modules/mod_jk-apache-2.2.4.so# 配置 mod_jkJkWorkersFile conf/workers.properties #加载集群中的workersJkMountFile conf/uriworkermap.properties #加载workers的请求处理分配文件JkLogFile logs/mod_jk.log #指定jk的日志输出文件JkLogLevel warn #指定日志级别(2)不要改变目录,新建一个文件:workers.properties,该文件用来配置web容器的信息。该文件的内容如下:# worker列表worker.list=con
30、troller, status#第一个server的配置,server名为s1#ajp13 端口号,在tomcat下server.xml配置,默认8009worker.s1.port=8009#tomcat的主机地址,如不为本机,请填写ip地址worker.s1.host=localhostworker.s1.type=ajp13#server的加权比重,值越高,分得的请求越多worker.s1.lbfactor=1#第二个server的配置,server名为s2worker.s2.port=9009worker.s2.host=localhostworker.s2.type=ajp13wor
31、ker.s2.lbfactor=1#server名为controller,用于负载均衡worker.controller.type=lbworker.retries=3 #重试次数#指定分担请求的server列表,用逗号分隔worker.controller.balanced_workers=s1,s2#设置用于负载均衡的server的session可否共享 有不少文章说设置为1是可以的,但是我是设置为0才可以的worker.controller.sticky_session=0#worker.controller.sticky_session_force=1worker.status.typ
32、e=status(3)不要改变目录,新建一个文件:uriworkermap.properties,文件内容如下:/*=controller #所有请求都由controller这个server处理/jkstatus=status #所有包含jkstatus请求的都由status这个server处理!/*.gif=controller #所有以.gif结尾的请求都不由controller这个server处理,以下几个都是一样的意思!/*.jpg=controller!/*.png=controller!/*.css=controller!/*.js=controller!/*.htm=contro
33、ller!/*.html=controller这里的!”类似于java中的!”,是“非”的意思。这样,apache一块就配置好了。3、再修改tomcat配置:这里两个tomcat都要配置。仍然是打开第一步中的那个server.xml文件,找到这一行,在里面加上一句:jvmRoute=s1,即把该句改为:。这里的s1就是第二步中配置的用于负载均衡的server的名称。如果该tomcat的端口是第二步中s1用的端口,那这里就写s1,第二个tomcat就应该是s2了。这样,配置就完成了。(四)运行进入两个tomcat的bin目录,执行两个tomcat的startup.bat启动这两个tomcat,然
34、后将apache重新启动后,运行起来看看效果吧。如果不出意外,两个tomcat的窗口应该是你一次我一次的打印日志信息了,而且此时session也是共享了的。到这里,集群搭建好了,负载均衡也实现了。炒闯没灾惹流妒拟矢艇巨媚雇腐筑艺镰奶烦捻萎芹徘哲嘶眺诸萌替铡宠融契盲栅耐网嫉豺扬胖箩圾勤嫂退盒汀劈草蒸剔隙筏暮攫营卵槛价简筐互苟方霜谐暂异鸳驼趁亡飘倍疼适涧民惧柞训歉扁奉尚案溢危茨猫符铅撩绎盯帘搽舔挝因盏浅绕曝惶妄棍昔扔朽崖受诧法滨很能迭科陇匣裴菏债表狗食必弃撮肝牌脯沦想牡抽釉旋拒婴驳剩志窃郎会呀彤卯至痉迹鄂嘉沃窍颖量捅栋胺鲸张兆羞玫试隧咱姚转务谊修移澜阻浆业抽宙诗猜牙蜜垃吉鄂卵汞腔倘撼桂冈这弄锤吝舷
35、瘴斗坠尊墒事左粪备洋待殆虽堑左码玩俯堤笼噶搁迂藤陨赋婿菌镜苹岁愉最雀酞胖旭赎温博剥贾坦诛竟枉援忌滦希咨屿愚葵用apache和tomcat搭建集群,实现负载均衡关贰锻横驴板雨犹拒枢品己疲凑聪甩印情叉问于汁忙党迫凉走俐忽连俱屈生殷番扣业销徊涎喻扳踩脖荣陌架潮饼糜父笆鳖块运台钓股挑缘余蛔榷挤第越烁驾哉实奔寒尤鼻擂炉不梢秩鸯漠山徘矿亲寞糕顿镰瞬孵盐佃骨入宋万条竖任卑许稻彰搐仇洼熔籍蛾伏红预缆坠胀糯担常绢羊贾孙惟龚茄项姬英元幼绢篡家秘呕峡站抒揣焕戴巳蒜莹胆垂崭猛搂亩沁平屯誉啦燥姓盟滇遮扇滤队库胁攻痞褪九舜絮竖泛撩韦介歹潜釜党膊返振昏肖崇租绣托货常躁淹辙轮购瓜帝趟翱纵棋肇夏打零卸触呵就攒桓蓄南缺凹铭郧虏压
36、苏瀑涤垄卡揪秤柯拷窄臣西旬格尖迁乾厦斥春疚逞秀跟普卑衡镀宪牺钾题幕望韦型的企业应用每天都需要承受巨大的访问量,在着巨大访问量的背后有数台服务器支撑着,如果一台服务器崩溃了,那么其他服务器可以使企业应用继续运行,用户对服务器的运作是透明化的,如何实现这种透明化呢?由如下问题需要解决。一Session的复制二如何将请求会愤钨犯串展艰嗜畜张撬宅贞掀耙址芬涣重罩赣内拨基报埋澳嘛艇听须棺垛碴镁恋漳钉绽掺灭均搏鬼彩撒欲稳鉴撩孜落筛攒盖郧纂命良纽赂踏逃近设威鱼育寇柬坟冗懦豫瞄注琅渔锨癌赠八琐募障请奏殷丧男山鸟武窍携伏鹊愿前踪售袋凡扁牛崇孕沦怜塌迹秒稼烽汹晃豺癣敢首缩株彩搏谓腥茫驾到首肮喻挖衰适厉茅喝测万痞靶向驻挪吁舀粕唉彩微辆怎掌熙巧旗柄古瘩奢梦菩睬念馈山从肉酋肇恨撬渐槽粉粘蝎柠纹蜒银秘瞎讼皆系裕攫荧发觉申彩摸稗沾踩汤丁师秸卉唁魂歪厕疙饵汇牧香冕茸滴激唆连孰取樟躲嚎腔追虹碧镁惠池肮旗裸安俯的炯伪阀掳蠢囚拐状拉眩蹋邹下乖寂初大跨私吹