加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > Asp教程 > 正文

在ASP中Cache技术的应用

发布时间:2023-08-23 15:15:36 所属栏目:Asp教程 来源:
导读:ASP的结构和体系在开发WEB应用程序方面越来越受欢迎,但是这些ASP.NET核心应用程序中的许多都是高流量的,并且在负载平衡的多服务器部署中运行,下文是为大家搜集的ASP中Cache技术的应用,希望对你学习有帮助!
ASP的结构和体系在开发WEB应用程序方面越来越受欢迎,但是这些ASP.NET核心应用程序中的许多都是高流量的,并且在负载平衡的多服务器部署中运行,下文是为大家搜集的ASP中Cache技术的应用,希望对你学习有帮助!
 
ASP从发布至今已经7年了,使用ASP技术已经相当成熟,自从微软推出了ASP.NET之后就逐渐停止了对ASP版本的更新。但是由于有很多人仍然习惯使用ASP来开发网站,所以,再次我将以一个简单的例子来说明在ASP中如何使用Cache。
 
  简单的说使用Cache基本原理是,把经常需要且获得代价昂贵的数据在内存中持续保存一定时间,以供这些数据可以被直接地全局地访问。例如,有一些数据需要从数据库多个表中查询获得,且几乎每个页面都要调用这些数据。
 
  这种情况下的最佳实现就是将这部分数据Cache起来,在ASP中的简单实现就是将这些数据的最终表达形式(例如HTML流)封装在string中然后存入ASP内置对象Application中(本文主要讨论的是动态Cache,简单的ASP 应用就省略)。这样做的好处是,在整个网站中可以全局调用这段HTML,而且Application是存在内存中,所以不用再去查询数据库,从而加快了响应时间并节省了服务器负荷。当然这是以消耗内存为代价的,是一个典型的以空间换时间的实例。
 
  使用这种方法虽然有很多好处,但是再遇到频繁变化的数据源(数据库)的时候,这种方法就可能不再适用,因为ASP Application对象有一个缺点,就是不能自动随数据源的变化而变化,或者控制刷新间隔。所以就需要开发人员编程来实现动态Cache。当然在程序设计的时候可以在所有进行改变数据源(数据库)操作时,就更新一次Appliction。从而使数据源(数据库)始终保持一致。这样做在编程上要考虑的问题会比较多,容易遗漏细节。所以除了特定情况我不推荐使用这种方法。
 
  我认为在ASP中最好的办法是用编程实现定时刷新Cache,也就是说给Application中储存的设一个过期时间。当然,在ASP中Application对象没有这样一个ExpireTime属性。这需要用程序实现。
 
  Code
 
  ASP:default.asp
 
<%@Language=VBScript%>
 
  <%Option Explicit%>
 
  <%Response.Buffer=True%>
 
每隔10秒刷新Cache:
 
  <%
 
  response.Flush
 
  GetHTMLStream
 
  response.Write
 
  HTMLStream
 
  %>

  ASP:getcache.asp
 
<%
 
  Const CACHE_DEFAULT_INTERVAL = 30 '每隔30秒刷新一次cache
 
  Dim HTMLStream
 
  Dim IsExpires
 
  IsExpires = CacheExpires
 
  Function CacheExpires
 
  Dim strLastUpdate
 
  Dim result strLastUpdate = Application("LastUpdate")
 
  If (strLastUpdate = "") Or (CACHE_DEFAULT_INTERVAL < DateDiff("s", strLastUpdate, Now)) Then
 
  result = true
 
  SetLastUpdateTime
 
  Else
 
  result = false
 
  End If
 
  CacheExpires = result
 
  End Function
 
Sub SetLastUpdateTime
 
  Application.Lock
 
  Application("LastUpdate") = CStr(now())
 
  Application.UnLock
 
  End Sub
 
  Sub GetHTMLStream
 
  If IsExpires Then
 
  UpdateHTMLStream
 
  End If
 
  HTMLStream=Application("CACHE_HTMLStream")
 
  End Sub
 
  Sub UpdateHTMLStream
 
  dim d
 
  d = FetchHTMLStream
 
  Application.Lock
 
  Application("CACHE_HTMLStream") = d
 
  Application.UnLock
 
  End Sub
 
  Function FetchHTMLStream
 
  Dim rs ,strSQL, strHTML
 
  Set rs = CreateObject("ADODB.Recordset")
 
  strSQL = "select categoryID , categoryname from categories"
 
  rs.Open strSQL, strConn,adOpenForwardOnly,adLockReadOnly
 
  strHTML = strHTML & "
 
"   strHTML = strHTML & rs.Fields("categoryname")   strHTML = strHTML & "
 
"
 
  rs.Close
 
  Set rs = Nothing
 
  FetchHTMLStream = strHTML
 
  End Function
 
  %>

  ASP:conn.asp

  <%
 
  dim strConn
 
  strConn = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=Northwind"
 
  %>
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章