背景:
现有公司的产品OA是采用ASP早先的技术开发,需要与目前最新的ASP.NET产品进行数据交互的应用。现有的ASP应用程序往往采用“ASP Sessions”,这是一种经典的ASP内置模式,即允许数据临时暂存在Web服务器内存中,其最大的限制因素就是ASP的session状态是依赖具体的服务器。而另一个更宽范围的解决方案就是很多Web服务器都可能别用于根据请求而指向的任何网络服务器。实际上就是所有的WEB服务器都像在一个农场中,因而任何在内存中的session状态将不会自动跟随请求。每个ASP服务器提供自己的session状态,除非用户很凑巧的返回统一服务器,造成系统session丢失。
通过使用服务器管理产品(如bigip)来强制用户会同意服务器内的Web农场来解决内存中ASP Session因服务器关系而造成的问题。为了达到这个目的,采用一个cookie在客户端工作,在服务器端来使用,让用户直接可以回到同一个服务器上的每个reqeust。这样可以限制扩展性,提高可维护性,避免服务器故障的风险(例如:session丢失服务器 失败)。
微软ASP.NET技术的出现终于解决了这个问题,可以让我们来存储session信息到Web Server和database或者其他域server。不错,问题解决了,我们还有必要用ASP代码吗?全部扔掉?如果这样做的话就会需要很大代价去重新使用.NET来重写ASP。看来还是不可行。另一种比较好的解决方案就是用迭代方法来部分移植代码到新的模型胜过重写ASP代码,在这个过程中如果旧的ASP代码和新的ASP.NET代码可以有一个共同的session状态而保持正常的工作,那么在整个生命周期中将会有益于你更好的规避风险.以下提供了几个解决方案从此略上来解决当采用经典的ASP Session因服务器关系而造成的问题。
1、用户自定义组或者使用ASP/ADO脚本去实现直接读写用户session数据到数据库;
2、用户自定义组件去直接访问ASP.NET Session数据;
3、通过Web Services建立ASP到ASP.NET的桥共享session;
在本文中,我们将讨论最后一种方案,其中也会包括一些Web Services与ASP/ADO定制数据库,和ASP Session 池的基本性能数据比较,呵呵...看完后你自己选择用哪个。
ASP to ASP.NET Bridge / Web-Service 方案
此方案中只是简单的实现了一个从ASP到ASP.NET的Web Services桥梁,如果你需要用数据库,只需要进行简单的配置(web.congfig和aspState 数据库)。代码中用来获得和设置session数据的方法写在一个Java Scirpt中,该文件必须保存在本地ASP程序中。
此Java Script实现MSXML,HTTP功能以便和server端交互,并负责将这些cookie回收给用户工作站。
优点:
支持与服务器无关的web-farm部署,提高可扩展性简单的实现ASP和ASP.NET的共同session状态松耦合,以session管理(无连接的HTTP接口, 80端口,可防火墙等)利用久经时间考验的ASP.NET Session实施。
缺点: 比ASP Session 内存池实现和数据库实现会慢。
ASP内存共享机制:
Session是采用类似字典或者哈希表的形势保存在Web Server内存中,ASP会保持session状态,提过一个特别的key给用户,当session会话开始时,这个key将保存cookie来纪录客户端发送到服务器的每一项请求,在服务器端,获得cookie的key,就可以知道request对应的session这种机制的一个明显的优势就是速度和方便,所有的session都会在一台服务器上保存,所以很开,但是正如前面所说的,将数据保存在一台服务器也是一个重大缺点,迫使用户返回同一台服务器检索session数据。这个减少了webform的优势,它只是一种低成本,大淘汰的策略,如果你只想实现简单功能,就可以用它。
优点:
内存纪录session,速度快,使用标准的ASP代码基础利用久经时间考验的ASP Session实施。
缺点:
它承载的能力有限,无法大规模开展网络农场(服务器依赖度高) ,服务器故障导致session丢失,内存占有率太大。
ASP/ADO数据库实现解决方案
建立了一个数据库连接之间的ASP应用服务器和数据库服务器。使数据被存在一个中央数据库或者数据库集群,然后分别从不同的服务器上的ASP程序执行。本文种只给出方案。获取和设置session的代码可以被放进一个Java Script文件中,支持基于Web Services获取的方法,允许ASP取代Java Script定制数据库模式,直接访问ASP.NET Session数据(如建立aspstate数据库)。
优点:
1、支持不依赖服务器的web form部署;
2、比ASP.NET Web服务更快;
缺点:
1、代码为定制执行(比较死板);
2、比内存共享ASP Session 慢;
3、需要数据库连接,从网络服务器到数据库服务器;
性能:
在下面数据中,列出了每种方案的性能比较,强调的是内存共享ASP Session池最快小型用户可以使用,采用数据库的话也会增加额外的开支,增加成本(除非你很有钱)。减 少网络回传,服务器请求是提高性能的唯一方法,微软的Web应用程序压力工具,是用来执行测试压力水平的25个线程为1分钟的时间从表中可以明显的看出用内存存储ASP Session比另外两种方式更快。
Method Get Data (ms) Set Data (ms)
5 values 1 value 5 values 1 value
In-memory ASP Sessions 46 9 34 7
ASP/ASP.NET web service individually 4321 864 3397 679
ASP/ASP.NET web service grouped 711 142 990 198
ASP/ADO database individually 346 69 841 168
ASP/ADO database grouped 163 33 860 172
代码描述ASP机制,
在asp中创建session如下:
Session("Sky") = "Blue";
在其他的页面中访问这些值采用:
var skyString = Session("Sky");
新的API语法:
下面的语法将会代替原来的ASP Session 语法,目的是在桥的使用中Java Script 函数可以进行封装设置一个关键值对;设置一个kye-value 类型session 数据,语法和值钱的ASP Session语法很相似,采用下面的代码可以把现有的设置ASP Session代码替换;
设置session数据:
SetSessionValue("Sky", "Blue");
获取session:
var SkyString = GetSessionValue("Sky");
这种方法建议在设置比较少的情况下用。
设置多个key-values对值
这些方法的最大开销在于设置每一个key-value,然后返回给Web Service,推荐用以下方法来设置(当超过3对以上的key-values)
设置session
var sessionInfo = NewSession();
sessionInfo.Add(“Sky”, "Blue");
sessionInfo.Add(“Grass”, “Green”);
SetSession(sessionInfo);
获得session
var sessionInfo = GetSession();
var skyString = sessionInfo.Item(“Sky”);
var grassString = sessionInfo.Item(“Grass”);
Java Script Example
<%@ Language="JScript" %>
<%
var sessionInfo = NewSession();
sessionInfo.Item("Sky") = "Blue";
sessionInfo.Item("Grass") = "Green";
SetSession(sessionInfo);
var retrievedSession = GetSession();
var sSky = retrievedSession.Item("Sky");
var sGrass = retrievedSession.Item("Grass");
Response.Write(sSky + "
");
Response.Write(sGrass + "
");
%>
Visual BASIC Example
<%@ Language="VBSCRIPT" %>
<%
Dim sessionInfo
Set sessionInfo = NewSession()
sessionInfo.Item("Sky") = "Blue"
sessionInfo.Item("Grass") = "Green"
SetSession(sessionInfo)
Dim retrievedSession
Set retrievedSession = GetSession()
Dim sSky
sSky = retrievedSession.Item("Sky")
Dim sGrass
sGrass = retrievedSession.Item("Grass")
Response.Write(sSky & "
")
Response.Write(sGrass & "
")
%>
共3页: 上一页 [1] 2 [3] 下一页 【内容导航】 第 1 页:背景 第 2 页:性能比较 第 3 页:Web Service实现代码
上一篇: 如何把客户端脚本文件嵌入程序集中 下一篇: ASP.NET AJAX框架调用后台代码的基本方法
查看所有评论()