1.网上有个朋友是提供这样的缓存实现机制的(http://tenglong.blog.51cto.com/180708/30028)
解决办法:
1、当客户端请求一个ASP页面的时候,首先将请求交给文件缓存模块处理,文件缓存判断请求是否是POST,如果是POST,则不执行缓存相关操作;同时判断请求是否是不需要缓存的请求。如果是不需要缓存的,则不进行缓存相关操作。
2、如果是需要使用缓存功能。通过URL地址以及QUERYSTRING参数,寻找缓存文件。如果找不到缓存文件,或者缓存文件过期。则重新获取缓存文件数据,并生成新的缓存文件数据。
3、将获取到的缓存文件数据发送到客户端,停止ASP文件的执行(response.end)。
2.网上另一个朋友写的技术文章摘录如下:()
Web访问量增加通常意味着以下资源需求的快速增长:
1、 网卡流量增加,需要消耗更多的CPU处理网络流量和网络I/O线程。
2、 需要更频繁的打开/关闭数据库连结(如果使用数据库技术—通常ASP都会采用数据库作为数据存储),严重消耗资源的事物数量、以及事务相互竞争资源引起的死锁、会增加网络I/O或者CPU消耗。
3、 如果采用session的话,IIS为了维持状态,会消耗更多内存,而内存消耗可能会引发物理内存不够,引起物理内存同辅存间的频繁交换,从而引起代码执行的停顿,web响应阻滞。
4、 由于访问的不到及时响应,会引起网页访问故障,导致用户刷新,从而加剧CPU、内存等资源需求。
实际上,考虑通常的web应用程序,很多时候的动态代码执行是不必要的。
二、ASP缓存的分类
擅自总结,ASP的缓存可以分为两类:
1、 文件缓存
所谓文件缓存,就是根据逻辑判断,一段时间内某个ASP的特定执行将不会有很大的变动,因而将内容以静态html的形式存放,然后以web的重定向技术让
客户端访问静态文件,以达到减少CPU、数据库资源等的需求。这样的应用很多,譬如很多论坛就是在回复贴子的时候将整个贴子重新生成一个静态文件,然后进
行重定向的,例如
donews.com的论坛。该成静态还有一个副作用(好处)--可以很容易被google等搜索引擎收录。一些所谓新闻发布系统的都采用了此技术。
2、 文件片断缓存
所谓文件缓存,也是基于逻辑判断,某部分数据(通常是需要消耗资源的大容量数据库查询取得)在一定时间内不会改变,所以我们可以将这些数据利用文件的形式
进行存储,当需要时候,可以通过读取文件来获取数据,避免增加数据库的负担。例如,我们通常将一些数据以xml格式存储,然后利用xslt技术实现显示
(xml处理通常需要大量CPU资源,所以通常是IE直接读取xml到客户端在客户的CPU上进行处理)。CSDN的论坛就是这样处理的。
3、 主存缓存
除此之外,还可以考虑在内存中处理缓存,将需要及时响应的内容存储在内存中,一旦访问需求,立即从快速的贮存中输送出去。如果极大量的访问需求集中在几个少量的页面或者主存足够多,我想采用主存缓存一定可以大幅度提高web访问性能。
三、如何实现/使用缓存
实现缓存需要考虑以下问题:
1、 哪些页面会在短时间内不会改变?
分析自己的站点,这样的页面很多。譬如一个站点通常都有新闻资讯类的栏目,这些栏目通常都是站点维护人员在一天的某个时间发布资料,之后很少改动页面。那
么这些页面就适合于采用静态文件缓存。实际上,所谓新闻发布系统就是这么做的,那么那也可以参考这些系统的思想改造自己的原有动态ASP页面。
2、 那些页面针对全部访问者都采用同一个逻辑生成(也就是不区分访问者)。
除了新闻资讯之类的栏目所有访问者都看一个界面外,论坛等消耗资源的应用一般也可以设计成统一逻辑生成(同一个贴子,张三李四看的都一样),针对这类应用
页面我们也可以采用静态缓存来实现。也可以考虑将数据片断化,利用脚本技术在服务器处理能力之外也就是客户端浏览器进行处理。
3、 采用缓存的代价和收获。
主要就是“空间换(响应)时间”。利用缓存技术将之后频繁需要的内容进行预处理,使之提高web服务器响应能力,更重要赢得访问者的欢心。
代价就是web空间需求增加,同时又可能影响到访问效果。
但我认为适当的缓存,是利大于弊的。
4、 那些地方不适宜采用缓存
动态查询页面,每个人的查询内容不一样,所以显示结果不大一样,所以不大可能将查询结果生成缓存,所以采用缓存较为复杂且缓存利用率底下,造成管理成本上什(假设你缓存了1000个查询关键字,那么管理这些关键字同缓存的对应也是麻烦事)。
其实实现方法特别的简单,大家只要看看下面这个简单的例子就明白了。
这是一个用来显示书籍分类的例子程序
DisplayBooks.ASP文件
- <%@ LANGUAGE=JavaScript %>
-
-
- 书籍分类; <%= getBooksListBox() %>
-
- <%
- function getBooksListBox()
- {
- BooksListBox = Application("BooksListBox")
- if (BooksListBox != null) return BooksListBox;
- crlf = String.fromCharCode(13, 10)
- BooksListBox = "< select name=Books>" + crlf;
- SQL = "Select * FROM Books orDER BY Name";
- cnnBooks = Server.CreateObject("ADODB.Connection");
- cnnBooks.Open("Books", "Admin","");
- rstBooks = cnnBooks.Execute(SQL);
- fldBookName = rstBooks("BookName");
- while (!rstBooks.EOF){
- BooksListBox = BooksListBox + " < option>" +
- fldBookName + "" + crlf;
- rstBooks.MoveNext();
- }
- BooksListBox = BooksListBox + ""
- Application("BooksListBox") = BooksListBox
- return BooksListBox;
- }
- %> .
借助了Application进来的实现缓存的。
很简单把,其实就是用了很简单的Application技术,而且就一句话的不同:
Application("BooksListBox") = BooksListBox
你可以验证一下你就会发现服务器上的请求数量会降低不少的。这种情况尤其适合与那些更新不是很频繁的网站内容,例如你一天(或则很长时间)只更新一次。
下面再讨论一种客户端的缓存技术这种技术也叫断开连接的ADO连接技术(翻译水平太次,听上去怎么这么别扭)。这种技术主要使用在用来保存用户个人
信息,例如用户的密码,代号等等上面。它主要使用了ADO的一些属性。同时也回答了一些网友曾经提到过的能否在Applocation中使用ADO对象的
问题。解释不清楚,下面让代码来发言:
文件GLOBAL.ASA
- < !--METADATA TYPE="TypeLib" FILE="C:\Program Files\Common
- Files\system\ado\msado15.dll"-- >
- < SCRIPT LANGUAGE=VBScript RUNAT="Server" >
- Sub Application_OnStart
- SQL = "Select UserName, Password FROM UserInfo"
- cnnUsers = "DSN=User"
- Set rsUsers = Server.CreateObject("ADODB.Recordset")
-
- rsCustomers.CursorLocation = adUseClient
- rsCustomers.Open SQL, cnnAdvWorks, adOpenStatic, AdLockReadOnly
-
- rsCustomers.ActiveConnection = Nothing
- Set Application("rsCustomers") = rsCustomers
- End Sub
文件Users.ASP
- <%
-
- Set yourUsers = Application("rsUsers").Clone
- Set UserName = yourUsers("UserName")
- Set Password = yourUsers("Password")
- Do Until yourUsers.EOF
- %>
- 用户姓名:< %= UserName % > 用户密码:< %= Password % >
- <%
- yourUsers.MoveNext
- Loop
- %>
ASP/Visual Basic代码
- <%
- Class Cls_Cache
-
-
-
-
-
-
-
-
-
-
-
- Public Reloadtime,MaxCount,CacheName
- Private LocalCacheName,CacheData,DelCount
-
- Private Sub Class_Initialize()
- Reloadtime=14400
- CacheName="Dvbbs"
- End Sub
-
- Private Sub SetCache(SetName,NewValue)
- Application.Lock
- Application(SetName) = NewValue
- Application.unLock
- End Sub
-
- Public Property Let Name(ByVal vNewValue)
- LocalCacheName=LCase(vNewValue)
- End Property
-
- Public Property Let Value(ByVal vNewValue)
- If LocalCacheName<>"" Then
- CacheData=Application(CacheName"_"&LocalCacheName)
- If IsArray(CacheData) Then
- CacheData(0)=vNewValue
- CacheData(1)=Now()
- Else
- ReDim CacheData(2)
- CacheData(0)=vNewValue
- CacheData(1)=Now()
- End If
- SetCache CacheName"_"&LocalCacheName,CacheData
- Else
- Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName."
- End If
- End Property
-
- Public Property Get Value()
- If LocalCacheName<>"" Then
- CacheData=Application(CacheName"_"&LocalCacheName)
- If IsArray(CacheData) Then
- Value=CacheData(0)
- Else
- Err.Raise vbObjectError + 1, "DvbbsCacheServer", " The CacheData Is Empty."
- End If
- Else
- Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName."
- End If
- End Property
-
- Public Function ObjIsEmpty()
- ObjIsEmpty=True
- CacheData=Application(CacheName"_"&LocalCacheName)
- If Not IsArray(CacheData) Then Exit Function
- If Not IsDate(CacheData(1)) Then Exit Function
- If DateDiff("s",CDate(CacheData(1)),Now()) < 60*Reloadtime Then ObjIsEmpty=False
- End Function
-
- Private Sub makeEmpty(SetName)
- Application.Lock
- Application(SetName) = Empty
- Application.unLock
- End Sub
-
- Public Sub DelCahe(MyCaheName)
- makeEmpty(CacheName"_"&MyCaheName)
- End Sub
- End Class
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- %>
阅读(1139) | 评论(0) | 转发(0) |