ASP.NET负载均衡的设定

网络 网络优化 网络运维
本文对ASP.NET的负载均衡的实现进行了简单的介绍,算是给大家投石问路了。可能过程稍显简略,更多的,还是希望大家能动手操作一下,发现问题。

在ASP.NET站点里面实现负载均衡,其实和其他WEB的实现方式基本类似。同样我们需要负载均衡器,之后是对会话状态的设置,我们要保证会话宝石和迁移正常。其中需要的配置并不是很多,在这里,我们制作一个简要介绍。

ASP.NET站点中做负载均衡:

基于HTTP协议我们可能发现我们要解决两点问题:

***,做到负载均衡,我们需要一个负载均衡器。

可以通过DNS轮询来做,在DNS服务器上配置为每次对我们做负载均衡的同一主机名的DNS查询得到不同的IP地址。这样的好处是配置简单投入较小,缺点是浏览器访问各个服务器的机会是均等的,不能根据服务器的负载程度自动把请求路由到负载较小的服务器。

可以通过专用的负载均衡设备,通过监测后台数台服务器的负载情况,自动把HTTP请求转发到负载较轻的服务器。另外必须监测后台服务器的IIS负载情况,而不是整台服务器的CPU负载。同时可能需要在负载均衡器和后台服务应用之间建立心跳连接,以避免出现某台服务器IIS进程或者其中跑的应用已经down掉,负载均衡器反而监测到这台服务器的负载最小而把大量请求转发的这台服务器,达到相反的效果。

第二,Session状态的保持和迁移。

由于HTTP协议的无状态性,我们一般是在Session中保存客户端的一些状态数据,负载均衡之后,前后两次HTTP请求所到达的服务器可能不是同一台,这就造成可能出现这样的情况,前一此请求处理中设置的session在第二次请求中变得不可用了,造成应用程序出错。所以我们要把 session跟随迁移。实现的方法就是session的统一存储和服务器间共享。

在ASP.NET中服务器保存session有五种方式,Off不说了,InProc是保存在服务器进程的内存中,显然不能满足要求。另外两种能够满足:

StateServer是把session保存在专门的状态服务器中。这样各台服务器都存取同一个StateServer,达到共享的目的。

SQLServer是把session保存在数据库中。同样能达到目的。

Custom自定制的存储方案,我们自己写当然能够实现。

比较一下,Custom这种自己实现比较麻烦一般不用,SQLServer可以利用数据库的cluster达到高性能和高可用性的目的,StateServer当然也可以通过手段达到高可用性,不过似乎不能实现集群所以性能也有所限制。

另外如果要做负载均衡在StateServer和SQLServer中配置session时,必须在web.config中重写 machineKey节点:

  1. <machineKey 
  2. validationKey="1234567890123456789012345678901234567890AAAAAAAAAA" 
  3. decryptionKey="123456789012345678901234567890123456789012345678" 
  4. validation="SHA1" 
  5. decryption="Auto" 
  6. /> 

否则各个应用服务器拿到的session还是不一样的。

责任编辑:佟健 来源: 互联网
相关推荐

2010-05-06 13:33:47

Asp.Net负载均衡

2012-05-16 10:24:26

ASP.NET性能优化

2010-05-07 12:23:23

nginx负载均衡

2010-05-06 15:43:18

NAT负载均衡

2010-05-06 12:11:24

NAT负载均衡

2010-05-06 16:58:10

Dns负载均衡

2010-05-10 14:29:11

线路负载均衡

2010-05-10 15:03:50

交换负载均衡

2009-07-22 17:45:35

ASP.NET教程

2009-07-28 17:17:19

ASP.NET概述

2009-08-03 14:22:33

什么是ASP.NET

2010-05-07 12:54:52

MySQL负载均衡

2010-04-27 13:20:38

负载均衡集群

2009-07-27 12:22:03

ASP.NET和ASPASP.NET入门教程

2009-07-27 10:35:33

TypeConvertASP.NET

2009-07-29 16:33:28

GreeterLogiASP.NET

2009-07-27 15:48:43

2009-07-29 14:52:12

IScriptContASP.NET

2009-07-29 11:19:03

JavaScriptASP.NET

2010-05-06 16:41:37

EIGRP负载均衡
点赞
收藏

51CTO技术栈公众号