应用win2000创建支持企业级访问的web集群服务器
http://www.usingdo.net/usingdonews/usingdo14.asp?typeid=1&usingdottid=4
作为microsoft公司全力推出的划时代操作系统,windows 2000的目标是彻底改变用户的业务模式,快速建立起商务企业级的互联网络信息系统。internet information services 5作为windows 2000网络信息服务中的核心部分,更加提供了强大的功能。如何创建支持企业级海量用户访问的web站点?对于例如电子商务网站和isp客户的企业级用户访问需求,保证服务的可用性和可靠性的最佳途径是建立web集群服务器。对于这一问题,windows 2000 advanced server提供了很好的可伸缩性服务。
web集群是由任意多台计算机组成的一种web站点。当设计者创建web集群时,可以选择三层web体系结构(由web服务器程序,com+应用程序和数据库应用程序组成)。三层体系结构的优点是设计者可以将以下的各层次任务分散到不同的服务器上,而不是将它们都结合在一台服务器上:
? 表示层:发布内容
? 商业逻辑层:运行应用程序
? 数据层:访问数据库
使用若干台低成本服务器,设计者可以很容易地处理大量的客户请求,而不会产生任何不必要的延时。在多台计算机之间共享负载对于企业用户支持重量级应用程序是至关重要的:例如,处理财政事务,访问数据库,支持公司intranet以及执行其他重要的日常活动。
一、相关术语
与web集群相关的两个重要术语是:集群和负载平衡。下面将简要地介绍一下这些术语在web集群中的含义。
1、集群
集群(clustering)是指按组划分不相互依赖,而又象管理一套单一系统一样对它们进行管理的一批服务器。一个服务器集群的最低要求如下:
? 至少有两台(或多台)联网服务器
? 集群管理软件,例如network load balancing 或 cluster service 集群管理软件。
这些集群软件执行如下的任务:
? 检测集群中哪台计算机有故障
? 从任何故障或服务器过载情况中恢复系统
? 在集群中所有的服务器上平衡请求负载
? 将这批服务器作为一个单一系统进行管理
将服务器集群起来成为一个系统,具有以下的优点:
? 总是能够处理到来的请求。因为来自于客户的请求可以在几台服务器之间平衡分配,从而减少了某台服务器过载的可能性。如果一台服务器过载或故障,负载平衡能够将请求重新在其余的服务器上分配,从而不会干扰客户的正常访问。
? 易于管理。不用单独地管理每台服务器,管理员只需将它们作为一个单元进行管理。
? 更大的可扩展性。设计者可以很容易地添加更多的服务器到集群中,或者对已有的服务器升级,而这并不会干扰客户的请求。
2、负载平衡
负载平衡(load balancing)是指在一个web集群中的多台服务器之间均衡地分配客户请求。一般地,负载平衡能增加系统吞吐率,而同时保持较低的响应时间。通过使用嵌入到windows 2000 server中的network load balancing,主机能够检测每一个来访的ip报文,只有符合接收条件的才接收它。每个network load balancing主机可以指定它将处理的报文百分比。作为一个选项,报文也可以平等地在所有的主机之间进行分配。如果一个主机故障,则负载平衡机制就会在剩余的主机之间重新分配报文。
通过使用network load balancing提供的可扩展性,当需求增加时,管理员可以升级已有的服务器或者将新计算机添加到集群中,以处理更多的ip通信量。
二、windows 2000 advanced server的分组负载平衡特性
我们下面将描述一下由windows 2000 advanced server 提供的负载平衡特性:network load balancing和cluster service 。
network load balancing 和cluster service 可以增强任何设施的安全可靠性。将它们分组是一种功能强大的方法,用来将后端数据库和事务系统与基于web的前端相结合,从而有效地提供给用户所需的可伸缩性、客户要求的高可用性。下面简要列出了每个解决方法,并给出如何将它们集成到一个三层配置中的实例:
? network load balancing 平衡那些主要由入站tcp/ip通信产生的负载。管理员可以在第一层上建立network load balancing,并且在集群的web服务器上平衡站点的访问。
? cluster service是管理员对那些要求高可用性的数据库服务进行分组的理想选择,这些数据库服务可以是microsoft sql server 7.0或其他数据敏感应用。管理员可以在第三层上建立cluster service,以完成诸如用户记帐和数据库定购的任务。
三、创建一个三层web集群
通过将这两个负载平衡的特性结合起来,这些特性将是三层体系结构应用程序的理想支持。例如,如果电子商务网站安装使用一个基于web的零售业务,则可以建立如下的集群:
? 在多台服务器上建立前端、用户界面(ui)层,使用network load balancing以平衡和分配客户tcp/ip连接。当通信量增加时,升级已有的集群或者添加计算机到配置中。这样就保证站点不论什么时候都能够处理访问请求。
? 使用cluster service,以便为应用程序和三层应用程序的数据服务层提供结点故障接管功能。这将创建一个可靠的平台用于数据库、消息和类似的应用服务。
由于传统的电子商务网站在单一的服务器上存放所有这三个层次,这种拓扑结构将会引入一些新的概念。
图1显示了一个示例web集群的特征,其中箭头表明内容是怎样进行复制的。
图1 示例web集群服务器结构
下面将举例说明如何创建web集群服务器。
1. 计算硬件需求
为了建立一个用于基于web的零售业务,设计者需要确定实际需要多少台web服务器来满足一个特定的应用。可以先从一台服务器开始,对其测试,而后在必要时对其进行升级。
在测试了单台服务器之后,设计者可能会发现服务器cpu的利用率特别高,而高速缓存命中率很低,并且在队列服务器中还留有许多请求。此时,可以通过添加处理器、内存、以及其他的硬件设备的方法来增加系统性能。如果这些解决方案也不能改善性能,则可以考虑添加另外的web服务器。
由于没有现成的数学公式用于确定需要添加的服务器最佳数目,因此设计者可以从多个web测试工具中进行选择,以帮助确定服务器的最佳数目。其中,一种工具是web application stress tool,该工具允许设计者模拟测试站点上具有几千个用户负载的情况。与system monitor工具相结合,设计者可以很容易地确定一台单一的web服务器的负载极限。web服务器的主要瓶颈在于http层,为了打破该瓶颈,设计者应该增加web服务器。
在测试了单台服务器之后,设计者可能决定升级,以便可以有效地处理用户的web访问请求。例如,可以添加两台web服务器以组成web集群的第一层。
2. 创建第一层
随着两个新web服务器的加入,设计者现在必须通过运行network load balancing来平衡这三个服务器间的请求负载。三台服务器从客户角度来看只是一台服务器。因为设计者只分配一个ip地址给一个集群中的三台服务器,因此管理集群十分容易。通过配置一台dns服务器,设计者可以使用ip地址192.16.1.10建立www.example.com。该ip地址代表了集群中的所有主机(此时为三台服务器)。关于如何分配一个ip地址,请参考windows 2000在线文档中的“configure tcp/ip settings(配置tcp/ip设置)”主题。
通过这种配置,设计者可以将站点拓扑结构由一台web服务器改变为三台。现在可以使用web application stress tool再次测试应用程序,将会看到性能立即得到了改善。接下来,再次测试集群,但这次要使用几千个用户进行模拟,确认站点消耗的资源远小于单台计算机运行iis 5所消耗的资源。如果应用程序需要更高的可用性,则可以添加更多的主机,最多为32台。
除了创建一个集群外,改善可靠性的另一种方法是禁止开发者在web服务器上开发产品。通过建立一台开发服务器(例如dev.example.com),设计者可以在此服务器上发布内容和测试其应用程序。而后能够将所有的授权和开发移交给服务器。
如果设计者在开发服务器(dev.example.com)上安装了frontpage server extensions,用户就可以使用frontpage连接到一台开发服务器,写入内容以及创建应用程序,而不用将应用程序引入到web产品服务器上。
一旦数据已准备好用于产品,则使用site server 3.0的content deployment特性将数据从阶段服务器复制到web服务器产品上。在三台web服务器间必须相同复制的单元是web内容。当设计者需要复制数据时,content deployment将很容易地实现该过程,从而可以节省大量时间。
当站点规模增长时,需要为每台服务器设置一个独立的日志文件。如果三台服务器在同一个web集群中,则必须分析三个单独的日志文件,可以预先地将所有日志导入到一个源中来帮助简化任务。site server usage analyst给设计者提供了一种简易的方法将这些文件导入到一个源中,而后设计者可以生成定制报告来表示web站点上的所有通信量。
要获得更高的可靠性和可用性,设计者可以添加另一个集群并将其限制在业务内容客户上。在图1中,该集群称为premium.example.com。这里的策略是将任务紧急的业务请求转换到premium.example.com,而将www.example.com用于一般公众服务。
一旦设计者添加了服务器,创建了开发服务器并且简化了日志,就将会注意到站点变得十分复杂。为了处理增加的复杂性和应用程序数量,设计者可能需要创建其它层,以便维持web站点的有效性和性能。
3. 创建第二层